ajklfhjkn 2019-08-07 15:49 采纳率: 100%
浏览 189
已采纳

为什么下列代码实现不了排序功能?

#include

int main()
{
int i,j,temp;
int array[6];
printf("input six numbers\n");
for(i=0;i<6;i++)
{
scanf("%d",&array[i]);
}
for(i=0;i<5;i++)
{
for(j=i;j<5;j++)
{
if(array[j]<array[j+1])
{
temp=array[j+1];
array[j+1]=array[j];
array[j]=temp;
}
}
}
for(i=0;i<6;i++)
{
printf("%d ",array[i]);
}
return 0;
}

  • 写回答

2条回答 默认 最新

  • Rotch 2019-08-07 15:54
    关注

    我先给你写解决代码,你先看着:可以用sort函数。
    sort(array, array + 6);
    里面有个cmp函数,可以写,可以不写。不懂再问我哈

    解决代码,改成如下:

    #include <stdio.h>
    
    int main() {
        int i,j,temp;
        int array[6];
        printf("input six numbers\n");
        for(i=0;i<6;i++) {
            scanf("%d",&array[i]);
        }
        for (i = 0; i < 5; i++)
            for (j = 0; j < 5 - i; j++) {
                if (array[j] < array[j + 1]) {
                    temp = array[j];
                    array[j] = array[j + 1];
                    array[j + 1] = temp;
            }
        }
        for(i = 0; i < 6; i++) {
            printf("%d ", array[i]);
        }
        return 0;
    }
    
    

    楼下说的不对,你每次从第 j = i 这里有问题。如果你要 j = i,你得确保 array[i - 1]绝对是最大或者最小。而一次排序下来,只能确定最后一个值,所以要 j < 5 - i这样才行

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

报告相同问题?

悬赏问题

  • ¥100 set_link_state
  • ¥15 虚幻5 UE美术毛发渲染
  • ¥15 CVRP 图论 物流运输优化
  • ¥15 Tableau online 嵌入ppt失败
  • ¥100 支付宝网页转账系统不识别账号
  • ¥15 基于单片机的靶位控制系统
  • ¥15 真我手机蓝牙传输进度消息被关闭了,怎么打开?(关键词-消息通知)
  • ¥15 装 pytorch 的时候出了好多问题,遇到这种情况怎么处理?
  • ¥20 IOS游览器某宝手机网页版自动立即购买JavaScript脚本
  • ¥15 手机接入宽带网线,如何释放宽带全部速度