选择排序------------(C每日一编程)

选择排序:

选择:每一趟从无序区选一个值最小(大)的元素,与无序区第一个元素交换

将n个数中最小数与第一个数交换,将n-1个数中最小数与第二个数交换,.......

结论:

n个数要进行n-1轮比较

第i轮要进行n-i次两两比较

cpp 复制代码
for(i=0;i<n-1;i++)
	{k = i;//擂主的下标也就是第二轮擂主的下标是i
	for (j = i + 1; j <= n - 1; j++)//j从i+1开始,小于等于n-1(<n也行)
		if(a[k]>a[j]) k=j;//a[k]和后面a[k+1]的元素比较,发现新擂主就换擂主下标
			if (k != i)//两个相等的数就不用自己与自己比较了,这个条件是少比较一次,不写这句也没关系
			{
				//a[i]与a[k]交换//擂主和最开始a[i]数去交换
			}
	}

一,找到十个整数的最小数,将其与第一个互换。

分析:找出最小数用打擂台法

cpp 复制代码
int a[10], i, min, k;
min = a[0]; k = 0;
for (i = 1; i < 10; i++)
	if (min > a[i]) { min = a[i]; k = i; }
t = a[0]; a[0] = a[k]; a[k] = t;

下面是选择排序法

cs 复制代码
int main() {
	int a[10], i, k,t,j,n;
	for (i = 0; i < 10; i++)
		scanf("%d", &a[i]);
	k = 0;
	for (i = 1; i < 10; i++)
		if (a[k] > a[i]) { k = i; };
	t = a[0]; a[0] = a[k]; a[k] = t;
	for (i = 0; i < 10; i++)
		printf("%d ", a[i]);
	return 0;
}
以上仅供参考。
相关推荐
saltymilk5 小时前
使用 C++ 模拟 ShaderLanguage 的 swizzle
c++·模板元编程
zone77395 小时前
006:RAG 入门-面试官问你,RAG 为什么要切块?
后端·算法·面试
CoovallyAIHub8 小时前
OpenClaw 近 2000 个 Skills,为什么没有一个好用的视觉检测工具?
深度学习·算法·计算机视觉
CoovallyAIHub8 小时前
CVPR 2026 | 用一句话告诉 AI 分割什么——MedCLIPSeg 让医学图像分割不再需要海量标注
深度学习·算法·计算机视觉
CoovallyAIHub8 小时前
Claude Code 突然变成了 66 个专家?这个 5.8k Star 的开源项目,让我重新理解了什么叫"会用 AI"
深度学习·算法·计算机视觉
兆子龙8 小时前
前端哨兵模式(Sentinel Pattern):优雅实现无限滚动加载
前端·javascript·算法
xlp666hub11 小时前
Leetcode第五题:用C++解决盛最多水的容器问题
linux·c++·leetcode
CoovallyAIHub12 小时前
9个视觉语言模型工厂实测:Qwen 87.9%碾压全场,你的显卡能跑哪个?
算法
程序设计实验室12 小时前
C# 扩展方法只会写 this 吗?C# 14 新语法直接把扩展方法玩出了花
c#
SparkX开源AI知识库12 小时前
手摸手带你安装OpenClaw并对接飞书
算法·架构