当前位置:   article > 正文

C语言题目:排序问题2

C语言题目:排序问题2

题目描述

将十个数进行从大到小的顺序进行排列

输入格式

十个整数

输出格式

以从大到小的顺序输出这个十个数

样例输入

1 2 3 4 5 6 7 8 9 10

样例输出

10 9 8 7 6 5 4 3 2 1

代码解析

1. 引入头文件

代码首先引入了stdio.h头文件,这是C语言标准输入输出库,用于处理输入输出函数。

2. 主函数定义

main函数是程序的入口点,它没有接收任何参数,也没有返回值。

3. 定义数组和变量

main函数内部,定义了以下变量:

  • int arr[10];:一个整型数组,用于存储用户输入的10个整数。
  • int temp;:一个整型变量,用于在排序过程中交换元素。
  • int p = 0;:一个标志变量,用于跟踪每次遍历是否发生了元素交换。

4. 输入循环

使用一个for循环来读取用户输入的10个整数:

  • scanf("%d", &arr[i]);:使用scanf函数读取一个整数,并将其存储在arr[i]中。

5. 冒泡排序逻辑

使用两层嵌套的for循环来实现冒泡排序,外层循环控制排序的总轮数,内层循环进行相邻元素的比较和交换:

  • 外层for循环变量i从0到8,表示需要进行9轮比较。
  • 内层for循环变量j从0到8,但在每轮比较中,只比较到第9-i个元素,因为后面的元素已经在前面的轮次中排好序了。
  • 如果arr[j]小于arr[j + 1],则交换这两个元素,并设置p为1,表示发生了交换。

6. 优化:提前结束排序

如果在某一轮遍历中没有发生任何交换(即p保持为0),则说明数组已经排好序,可以提前结束排序。

7. 输出排序结果

使用一个for循环遍历排序后的数组,并使用printf函数输出每个元素。

8. 程序结束

main函数返回0,表示程序正常结束。

源代码

  1. #include <stdio.h>
  2. int main(void)
  3. {
  4. int arr[10];
  5. int temp;
  6. int p = 0;//用于遍历一次是否发生交换
  7. for (int i = 0; i < 10; i++)
  8. {
  9. scanf("%d", &arr[i]);
  10. }
  11. for (int i = 0; i < 9; i++)
  12. {
  13. p = 0;
  14. for (int j = 0; j < 9; j++)
  15. {
  16. if (arr[j] < arr[j + 1])
  17. {
  18. temp = arr[j];
  19. arr[j] = arr[j + 1];
  20. arr[j + 1] = temp;
  21. p = 1;
  22. }
  23. }
  24. if (p == 0)
  25. break;
  26. }
  27. for (int i = 0; i < 10; i++)
  28. {
  29. printf("%d ", arr[i]);
  30. }
  31. return 0;
  32. }

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/盐析白兔/article/detail/741863
推荐阅读
相关标签
  

闽ICP备14008679号