MaxZc


私信TA

用户名:MaxZc8527

访问量:899

签 名:

Don't worry,You will be better and better.

等  级
排  名 7047
经  验 1299
参赛次数 1
文章发表 7
年  龄 0
在职情况 学生
学  校
专  业

  自我简介:

TA的其他文章

以下是个人的一些想法.....

解题思路:

1.找出一个最大数/最小数,交换到数组最前面
2.在剩下的数里,再找出一个最大数/最小数,交换到剩下数的最前面
3.重复2步骤,直至所有数都排列好

注意事项:

1.为什么说选择法是一种不稳定的算法,因为它可能会打乱相同数字的顺序
2.选择法与冒泡法的区别:1.比较次数的初始值不同  

                                            选择法:j = i ;

                                            冒泡法:j = 0;

                                        2.比较次数不同

                                            选择法:j<数组元素个数;

                                            冒泡法:j<数组元素个数 - 1 - i;

                                        3.Swap(交换)所处的位置不同

                                            选择法:Swap交换的位置处于外循环里面

                                            冒泡法:Swap交换的位置处于内循环里面

参考代码:

#include <stdio.h>
int main()
{
	int temp, min, a[10];
	for (int i = 0; i < 10; i++)
		scanf("%d", &a[i]);
	for (int i = 0; i < 9; i++)
	{
		min = i;
		for (int j = i; j < 10; j++)
			if (a[min] < a[j])
				min = j;
		temp = a[i];
		a[i] = a[min];
		a[min] = temp;
	}
	for (int i = 0; i < 10; i++)
	{
		printf("%d\n",a[i]);
	}
    return 0;
}



 

0.0分

0 人评分

看不懂代码?想转换其他语言的代码? 或者想问其他问题? 试试问问AI编程助手,随时响应你的问题:

编程语言转换

万能编程问答  

代码解释器

代码纠错

SQL生成与解释

  评论区