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条)

报告相同问题?

悬赏问题

  • ¥15 高价求中通快递查询接口
  • ¥15 解决一个加好友限制问题 或者有好的方案
  • ¥15 关于#java#的问题,请各位专家解答!
  • ¥15 急matlab编程仿真二阶震荡系统
  • ¥20 TEC-9的数据通路实验
  • ¥15 ue5 .3之前好好的现在只要是激活关卡就会崩溃
  • ¥50 MATLAB实现圆柱体容器内球形颗粒堆积
  • ¥15 python如何将动态的多个子列表,拼接后进行集合的交集
  • ¥20 vitis-ai量化基于pytorch框架下的yolov5模型
  • ¥15 如何实现H5在QQ平台上的二次分享卡片效果?