鱼C论坛

 找回密码
 立即注册
查看: 1574|回复: 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
#include <stdio.h>

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

void quick_sort(int* arr, int left, int right) {
    if (left >= right) {
        return;
    }

    int i = left;
    int j = right;
    int key = arr[left];

    while (i < j) {
        while (i < j && arr[j] >= key) {
            j--;
        }

        arr[i] = arr[j];

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

        arr[j] = arr[i];
    }

    arr[i] = key;

    quick_sort(arr, left, i - 1);
    quick_sort(arr, i + 1, right);
}

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

    quick_sort(array, 0, 9);

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

    return 0;
}
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

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

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

void quick_sort(int* arr, int left, int right) {
    if (left >= right) {
        return;
    }

    int i = left;
    int j = right;
    int key = arr[left];

    while (i < j) {
        while (i < j && arr[j] >= key) {
            j--;
        }

        arr[i] = arr[j];

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

        arr[j] = arr[i];
    }

    arr[i] = key;

    quick_sort(arr, left, i - 1);
    quick_sort(arr, i + 1, right);
}

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

    quick_sort(array, 0, 9);

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

    return 0;
}
想知道小甲鱼最近在做啥?请访问 -> 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。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

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

那应该怎么修改呢?
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

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

本版积分规则

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

GMT+8, 2025-2-25 19:44

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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