选择和冒泡排序

1选择排序:基本思想是每次在若干个无序数中找出最小数(递增排序)的位置,即下标,然后和一个数交换位置。若要递减排序,只需每次找到最大数的下标即可。注意,他的时间复杂度是O(n)所以用他的时候,数据规模越小越好。

2冒泡排序:与选择排序不同,他是从左向右进行相邻两个元素的两两比较,若是递增排序,若a[N-2]与a[N-1]比较前者较大则两者进行交换。

#include<stdio.h>
void Select(int* a)//选择法排序
{
	int b,tmp;
	for (int i = 0; i < 10; i++)
	{
		for (int j = i + 1; j < 10; j++)//遍历判断最小的数,并进行更新
		{
			if (a[j] < a[i])
			{
				tmp = a[i];
				a[i] = a[j];
				a[j] = tmp;
			}
		}
		printf("%d ", a[i]);

	}
}
void Maopao(int* arr,int len)//冒泡法排序
{
	int tmp,flg=1;
	for (int i = 0; i < len-1; i++)
	{
		for (int j = 0; j < len-i-1; j++)
		{
			if (arr[j] > arr[j+1])
			{
				tmp = arr[j];
				arr[j] = arr[j + 1];
				arr[j+1] = tmp;   
			}
		}
	}
	for (int i = 0; i < len; i++) printf("%d ", arr[i]);
	printf("\n");
}
int main()
{
   int b[10];
int c[]={1,2,4,56,78,34,12,9,0};
	for (int i = 0; i < 10; i++)
	{
		scanf("%d", &b[i]);
	}
    Select(b);
	printf("\n");
	Maopao(c,sizeof(c)/sizeof(c[0]));
 return 0;
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值