粽子皮蛋粥 2022-11-06 11:13 采纳率: 57.1%
浏览 23
已结题

四个数冒泡排序不明白了

为什么四个for循环中都是<而不是<=
为啥第三个for循环中是NUM-i-1,为什么是-1之后再-i
为啥在最后面再写个for循环
#include<stdio.h>
#define NUM 4
int main()
{
int arr[NUM],i,j,temp;//NUM是数组长度//
printf("input %d numbers:\n",NUM);
for(i=0;i<NUM;i++)
scanf("%d",&arr[i]);
for(i=0;i<NUM-1;i++)
{
for(j=0;j<NUM-i-1;j++)
{
if(arr[j]>arr[j+1])//比较相邻的元素大小,目的是将最大的元素选出排到最后//
{
temp=arr[j];
arr[j]=arr[j+1];
arr[j+1]=temp;
}
}
}
printf("排序之后为:\n");
for(i=0;i<NUM;i++)
printf("%d",arr[i]);
return 0;
}

  • 写回答

1条回答 默认 最新

  • 爱音斯坦牛 全栈领域优质创作者 2022-11-06 11:27
    关注

    因为NUM是数组长度,数组最大下标是NUM-1
    比如十个数,NUM=10,则数组下标为0-9,第一层循环是趟数,十个数要九趟,所以0-8为九个数,即<NUM。第二层循环是两两比较,因为有个a[j+1],所以j最大到8!然后减去每一趟比较已经排好的。
    即NUM-1-i。
    有帮助的话采纳一下哦!

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论 编辑记录

报告相同问题?

问题事件

  • 系统已结题 11月17日
  • 已采纳回答 11月9日
  • 修改了问题 11月6日
  • 创建了问题 11月6日

悬赏问题

  • ¥15 PointNet++的onnx模型只能使用一次
  • ¥20 西南科技大学数字信号处理
  • ¥15 有两个非常“自以为是”烦人的问题急期待大家解决!
  • ¥30 STM32 INMP441无法读取数据
  • ¥15 R语言绘制密度图,一个密度曲线内fill不同颜色如何实现
  • ¥100 求汇川机器人IRCB300控制器和示教器同版本升级固件文件升级包
  • ¥15 用visualstudio2022创建vue项目后无法启动
  • ¥15 x趋于0时tanx-sinx极限可以拆开算吗
  • ¥500 把面具戴到人脸上,请大家贡献智慧,别用大模型回答,大模型的答案没啥用
  • ¥15 任意一个散点图自己下载其js脚本文件并做成独立的案例页面,不要作在线的,要离线状态。