粽子皮蛋粥 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 ubuntu22.04上安装ursim-3.15.8.106339遇到的问题
  • ¥15 求螺旋焊缝的图像处理
  • ¥15 blast算法(相关搜索:数据库)
  • ¥15 请问有人会紧聚焦相关的matlab知识嘛?
  • ¥15 网络通信安全解决方案
  • ¥50 yalmip+Gurobi
  • ¥20 win10修改放大文本以及缩放与布局后蓝屏无法正常进入桌面
  • ¥15 itunes恢复数据最后一步发生错误
  • ¥15 关于#windows#的问题:2024年5月15日的win11更新后资源管理器没有地址栏了顶部的地址栏和文件搜索都消失了
  • ¥100 H5网页如何调用微信扫一扫功能?