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,表示程序正常结束。

源代码

#include <stdio.h>
int main(void)
{
	int arr[10];
	int temp;
	int p = 0;//用于遍历一次是否发生交换
	for (int i = 0; i < 10; i++)
	{
		scanf("%d", &arr[i]);
	}
	for (int i = 0; i < 9; i++)
	{
		p = 0;
		for (int j = 0; j < 9; j++)
		{
			if (arr[j] < arr[j + 1])
			{
				temp = arr[j];
				arr[j] = arr[j + 1];
				arr[j + 1] = temp;
				p = 1;
			}
		}
		if (p == 0)
			break;
	}
	for (int i = 0; i < 10; i++)
	{
		printf("%d ", arr[i]);
	}
	return 0;
}
相关推荐
资源补给站1 小时前
大恒相机开发(2)—Python软触发调用采集图像
开发语言·python·数码相机
m0_748247551 小时前
Web 应用项目开发全流程解析与实战经验分享
开发语言·前端·php
6.941 小时前
Scala学习记录 递归调用 练习
开发语言·学习·scala
FF在路上2 小时前
Knife4j调试实体类传参扁平化模式修改:default-flat-param-object: true
java·开发语言
余额不足121382 小时前
C语言基础十六:枚举、c语言中文件的读写操作
linux·c语言·算法
众拾达人2 小时前
Android自动化测试实战 Java篇 主流工具 框架 脚本
android·java·开发语言
皓木.3 小时前
Mybatis-Plus
java·开发语言
不良人天码星3 小时前
lombok插件不生效
java·开发语言·intellij-idea
源码哥_博纳软云3 小时前
JAVA同城服务场馆门店预约系统支持H5小程序APP源码
java·开发语言·微信小程序·小程序·微信公众平台
学会沉淀。3 小时前
Docker学习
java·开发语言·学习