粽子皮蛋粥 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 BP神经网络控制倒立摆
  • ¥20 要这个数学建模编程的代码 并且能完整允许出来结果 完整的过程和数据的结果
  • ¥15 html5+css和javascript有人可以帮吗?图片要怎么插入代码里面啊
  • ¥30 Unity接入微信SDK 无法开启摄像头
  • ¥20 有偿 写代码 要用特定的软件anaconda 里的jvpyter 用python3写
  • ¥20 cad图纸,chx-3六轴码垛机器人
  • ¥15 移动摄像头专网需要解vlan
  • ¥20 access多表提取相同字段数据并合并
  • ¥20 基于MSP430f5529的MPU6050驱动,求出欧拉角
  • ¥20 Java-Oj-桌布的计算