hahahahaqg 2023-01-22 20:53 采纳率: 14.3%
浏览 25
已结题

C语言,想问一下快排的代码哪里写错了QAQ



```c
#include<stdio.h>
void swap(int* a,int* b)
{
    int temp=*a;
    *a=*b;
    *b=temp;
}
void kp(int a[],int l,int r)
{
    int i=l,j=r,shao=(i+j)/2;
    while(i<=j)
    {
        while(a[i]<shao)i++;
        while(a[j]>shao)j--;
        if(i<=j)
        {
            swap(&a[i],&a[j]);
            i++;j--;
        }
    }
    if(l<j)kp(a,l,j);
    if(i<r)kp(a,i,r);
}
int main()
{
    int x[5]={5,6,8,3,7},l=0,r=4;
    kp(x,l,r);
    for(int i=0;i<5;i++)
    {
        printf("%d ",x[i]);
    }
}


```

  • 写回答

3条回答 默认 最新

  • 社区专家-Monster-XH 2023-01-22 21:02
    关注

    错误在于,条件判断中使用了变量shao作为基准值,而shao实际上是数组中间元素的下标。正确的做法应该是使用a[shao]作为基准值,来确定应该交换哪些元素。

    另外,在递归调用kp函数时,还存在问题。对于左半部分,应该是kp(a, l, j),而不是kp(a, l, j);对于右半部分,应该是kp(a, i, r),而不是kp(a, i, r)。

    这些错误的修正应该能使代码正常运行。

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(2条)

报告相同问题?

问题事件

  • 系统已结题 1月30日
  • 已采纳回答 1月22日
  • 修改了问题 1月22日
  • 创建了问题 1月22日

悬赏问题

  • ¥15 GD32 SPI通信时我从机原样返回收到的数据怎么弄?
  • ¥15 phython读取excel表格报错 ^7个 SyntaxError: invalid syntax 语句报错
  • ¥20 @microsoft/fetch-event-source 流式响应问题
  • ¥15 ogg dd trandata 报错
  • ¥15 高缺失率数据如何选择填充方式
  • ¥50 potsgresql15备份问题
  • ¥15 Mac系统vs code使用phpstudy如何配置debug来调试php
  • ¥15 目前主流的音乐软件,像网易云音乐,QQ音乐他们的前端和后台部分是用的什么技术实现的?求解!
  • ¥60 pb数据库修改与连接
  • ¥15 spss统计中二分类变量和有序变量的相关性分析可以用kendall相关分析吗?