【问题标题】:Help implementing quick sort [closed]帮助实现快速排序[关闭]
【发布时间】:2011-10-17 20:18:53
【问题描述】:

这就是我所拥有的,但它不起作用。不知道为什么...问题可能出在 quick_sort 函数中。

#include <stdio.h>
#include <stdlib.h>

void quick_sort(int * a, int l, int r);
void swap(int * a, int i, int j);

int main(void)
{
  #define N 10
  int a[N], i;
  for (i = 0; i < N; ++i) {
    a[i] = rand();
    printf("%d\n", a[i]);
  }
  quick_sort(a, 0, N - 1);
  for (i = 0; i < N; ++i)
    printf("%d\n", a[i]);
  return 0;
  #undef N
}

void quick_sort(int * a, int l, int r)
{
  int i, j;
  if (l < r) {
    swap(a, rand() % (r - l + 1), r);
    i = l;
    for (j = l; j < r; ++j)
      if (a[j] < a[r]) {
        swap(a, i, j);
        ++i;
      }
    swap(a, i, r);
    quick_sort(a, l, i - 1);
    quick_sort(a, i + 1, r);
  }
}

void swap(int * a, int i, int j)
{
  int k;
  k = a[i];
  a[i] = a[j];
  a[j] = k;
}

【问题讨论】:

  • 在什么情况下不起作用...?
  • 请提供您的datasetyour outputexpected output
  • l 是一个可怕的标识符。在许多情况下,大多数单字母标识符都很糟糕,但在任何情况下,l 都非常糟糕!考虑重命名变量(lowhighleftrightllimrlim,...)
  • 拉兹比,哈里。解决了。不过还是谢谢。下午。是的,一般来说。但这对我的编辑器来说不是问题,这只是一个玩具实现。
  • l 只有在你使用可怕的字体时才可怕......

标签: c sorting quicksort


【解决方案1】:

修复此行:swap(a, rand() % (r - l + 1), r);

应该是:swap(a, l + rand() % (r - l + 1), r);

【讨论】:

  • 谢谢,解决了!起初我以为l1...
猜你喜欢
  • 2017-08-15
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 2013-08-09
  • 2016-01-10
  • 1970-01-01
  • 1970-01-01
相关资源
最近更新 更多