C语言题目:选择排序

题目描述

用选择法对10个整数从小到大排序。

输入格式

输入10个无序的数字

输出格式

排序好的10个整数

样例输入

4 85 3 234 45 345 345 122 30 12

样例输出

3
4
12
30
45
85
122
234
345
345

代码分析

1. 引入头文件

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

2. 主函数定义

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

3. 定义数组和变量

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

  • int number[10];:一个整型数组,用于存储用户输入的10个整数。
  • int exchange;:一个整型变量,用于在排序过程中交换元素。
  • int flag;:一个整型变量,用作标记找到的最小元素的索引。

4. 输入循环

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

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

5. 选择排序逻辑

使用嵌套的for循环来实现选择排序:

  • 外层for循环变量i从0到9,代表每轮选择排序中已经排序好的元素的索引。
  • 内层for循环变量ji + 1到9,用于查找未排序部分的最小元素。

在内层循环中:

  • 通过比较number[flag]number[j]找到未排序部分的最小元素的索引,并将其存储在flag中。

6. 交换元素

如果找到的最小元素的索引flag不等于当前的索引i,则将number[i]number[flag]交换。

7. 输出排序结果

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

8. 程序结束

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

源代码

#include <stdio.h>

int main(void)
{
	int number[10];
	int exchange;	//交换
	int flag;	//标记


	for (int i = 0; i < 10; i++)
		scanf("%d", &number[i]);

	for (int i = 0; i < 10; i++)
	{
		flag = i;
		for (int j = i + 1; j < 10; j++)
		{
			if (number[flag] >= number[j])
			{
				flag = j;
			}
		}
		if (flag != i)
		{
			exchange = number[i];
			number[i] = number[flag];
			number[flag] = exchange;
		}
	}


	for (int i = 0; i < 10; i++)
	{
		printf("%d\n", number[i]);
	}


	return 0;
}

  • 11
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值