鱼C论坛

 找回密码
 立即注册
查看: 1813|回复: 3

[已解决]求助!!!

[复制链接]
发表于 2023-9-18 08:21:57 | 显示全部楼层 |阅读模式
20鱼币
#include <stdio.h>

void quick_sort(int length, int array[]);

void quick_sort(int length, int array[])
{
    int i, j, mid, num;
    mid = length / 2 - 1;
    for(i = 0, j = length - 1; i <= j;)
    {
        if(array[i] < array[mid])
        {
            i++;
        }

        if(array[j] >= array[mid])
        {
            j--;
        }

        if(array[i] >= array[mid] && array[j] < array[mid])
        {
            num = array[i];
            array[i] = array[j];
            array[j] = num;
        }

        printf("i = %d, j = %d\n", i, j);
    }

    for(i = 0; i < length - 1; i++)
    {
        if(array[i] > array[i + 1])
        {
            quick_sort(length, array);
        }
    }
}

int main(void)
{
    int i;
    int array[10] = {5, 2, 9, 4, 7, 8, 6, 3, 0, 1};

    quick_sort(10, array);

    for(i = 0; i < 10; i++)
    {
        printf("%d ", array[i]);
    }

    return 0;
}
问题描述   为什么函数quick_sort里的array[mid]=0而不是7?
最佳答案
2023-9-18 08:21:58
  1. #include <stdio.h>

  2. void quick_sort(int* arr, int left, int right);

  3. void quick_sort(int* arr, int left, int right) {
  4.     if (left >= right) {
  5.         return;
  6.     }

  7.     int i = left;
  8.     int j = right;
  9.     int key = arr[left];

  10.     while (i < j) {
  11.         while (i < j && arr[j] >= key) {
  12.             j--;
  13.         }

  14.         arr[i] = arr[j];

  15.         while (i < j && arr[i] <= key) {
  16.             i++;
  17.         }

  18.         arr[j] = arr[i];
  19.     }

  20.     arr[i] = key;

  21.     quick_sort(arr, left, i - 1);
  22.     quick_sort(arr, i + 1, right);
  23. }

  24. int main(void) {
  25.     int i;
  26.     int array[10] = {5, 2, 9, 4, 7, 8, 6, 3, 0, 1};

  27.     quick_sort(array, 0, 9);

  28.     for(i = 0; i < 10; i++)
  29.     {
  30.         printf("%d ", array[i]);
  31.     }

  32.     return 0;
  33. }
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2023-9-18 08:21:58 | 显示全部楼层    本楼为最佳答案   
  1. #include <stdio.h>

  2. void quick_sort(int* arr, int left, int right);

  3. void quick_sort(int* arr, int left, int right) {
  4.     if (left >= right) {
  5.         return;
  6.     }

  7.     int i = left;
  8.     int j = right;
  9.     int key = arr[left];

  10.     while (i < j) {
  11.         while (i < j && arr[j] >= key) {
  12.             j--;
  13.         }

  14.         arr[i] = arr[j];

  15.         while (i < j && arr[i] <= key) {
  16.             i++;
  17.         }

  18.         arr[j] = arr[i];
  19.     }

  20.     arr[i] = key;

  21.     quick_sort(arr, left, i - 1);
  22.     quick_sort(arr, i + 1, right);
  23. }

  24. int main(void) {
  25.     int i;
  26.     int array[10] = {5, 2, 9, 4, 7, 8, 6, 3, 0, 1};

  27.     quick_sort(array, 0, 9);

  28.     for(i = 0; i < 10; i++)
  29.     {
  30.         printf("%d ", array[i]);
  31.     }

  32.     return 0;
  33. }
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2023-9-18 08:22:01 | 显示全部楼层
在这段代码中,我们可以看到mid的值被计算为length / 2 - 1。在这个特定的例子中,length的值为10,因此mid的值为4。在main函数中,我们可以看到数组array的第5个元素的值为7。然而,在quick_sort函数中,我们并没有看到任何代码来改变array[mid]的值。因此,在函数中,array[mid]的值应该是数组中第5个元素的值,即7。如果array[mid]的值为0,则可能是由于在调用函数时,数组中第5个元素的值被更改为0。
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

 楼主| 发表于 2023-9-18 09:43:13 | 显示全部楼层
isdkz 发表于 2023-9-18 08:22
在这段代码中,我们可以看到mid的值被计算为length / 2 - 1。在这个特定的例子中,length的值为10,因此mid ...

那应该怎么修改呢?
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2025-4-22 05:05

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表