穆穆青风至 2022-01-12 21:24 采纳率: 97.4%
浏览 39
已结题

c语言,实现了一个快速排序算法


# include<stdio.h>
#include<string.h>
#pragma warning(disable:4996)
void sort(int a[],int m,int n) {
    int left = m;
    int right = n;
    int p = a[left];
    while (left<right)
    {
        while (a[right] > p && right > left)
        {
            right--;
        }
        a[left] = a[right];
        while (a[left]<p && right>left)
        {
            left++;
        }
        a[right] = a[left];
    }
    a[left] = p;
    sort(a, m, left - 1);
    sort(a, left +1, n);
}

int main()
{
    int a[] = { 5,4,4,3,1};
    sort(a,0,4);
    for (int i = 0; i < 5; i++) {
        printf("%d\n", a[i]);
    }
    return 0;
}

```不清楚是哪里出问题了,目前我只看到以下错误信息
![img](https://img-mid.csdnimg.cn/release/static/image/mid/ask/08983839914610.png "#left")
  • 写回答

2条回答 默认 最新

  • 了不起的旭baobao 2022-01-25 20:28
    关注

    你的代码有两处错误
    1.传入的左边界必须小于等于右边界 如果左边界大于右边界,要直接返回
    2.对于升序来说,right指针是为了找到第一个比枢轴小的元素,left是找到第一个比枢轴大的元素,然后相互交换;
    如果遇到等于枢轴的,指针要继续动(right--,left++),
    所以循环条件应该是 while (a[right]>=p && right>left) 和 while (a[left]<=p && right>left)

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

报告相同问题?

问题事件

  • 系统已结题 2月25日
  • 已采纳回答 2月17日
  • 提问应符合社区要求 1月12日
  • 创建了问题 1月12日

悬赏问题

  • ¥15 如何解决蓝牙通话音频突发失真问题
  • ¥15 安装opengauss数据库报错
  • ¥15 【急】在线问答CNC雕刻机的电子电路与编程
  • ¥60 在mc68335芯片上移植ucos ii 的成功工程文件
  • ¥15 笔记本外接显示器正常,但是笔记本屏幕黑屏
  • ¥15 Python pandas
  • ¥15 蓝牙硬件,可以用哪几种方法控制手机点击和滑动
  • ¥15 生物医学数据分析。基础课程就v经常唱课程舅成牛逼
  • ¥15 云环境云开发云函数对接微信商户中的分账功能
  • ¥15 空间转录组CRAD遇到问题