非递归排序_笔记

参考文章:

一步一步写算法(之非递归排序)

http://blog.csdn.net/feixiaoxing/article/details/6844826


排序可以分为两种:

a)非递归排序,它主要按照非递归的方法对数据进行排序,也就是说主要数据的移位和循环来完成;

b)递归方法,我们在排列当前数据的时候首先把子数据排列有序,然后才会排列当前的数据。这种不断递归调用的方法就是递归排序。


【1】冒泡排序

void bubble_sort(int array[], int length)
{
	int inner = 0, outer = 0;
	int median = 0;

	if(NULL == array || 0 == length)
		return;

	for(outer = length-1; outer >= 1; outer --){
		for(inner = 0; inner < outer; inner ++){
			if(array[inner] > array[inner + 1]){
				median = array[inner];
				array[inner] = array[inner + 1];
				array[inner + 1] = median;
			}
		}
	}
}
改进:若遍历一次数组,没有发生位移动作,则可以认为该数组已经排序完成。

【2】插入排序

插入排序将数据逐个与已排好序的数据对比。

冒泡排序是将数据与未排序数据对比,形成有序数组

void insert_sort(int array[], int length)
{
	int inner = 0;
	int outer = 0;
	int median = 0;
	if(NULL == array || 0 == length)
		return;

	for(outer = 1; outer <length; outer ++){
		for(inner = outer; inner >= 1; inner --){
			if(array[inner] < array[inner -1]){
				median = array[inner];
				array[inner] = array[inner -1];
				array[inner -1] = median;
			}else{
				break;
			}
		}
	}
}

【3】希尔排序

首先按照一个序列递减的方法逐渐进行排序。比如说有10个数据,我们按照序列5、3、1的顺序进行排序。首先是5,那么我们对1和6、2和7、3和8、4和9、5和10进行排列;第二轮是3,那么对数据1、4、7、10排列,再对2、5、8进行排列,以及3、6、9排列;第三轮就和冒泡排序一样了,以此对每个数据进行排列。它的优势就是让整个队列基本有序,减少数据移动的次数,从而降低算法的计算复杂度。

void shell_sort(int array[], int length, int step)
{
	int inner = 0;
	int outer = 0;
	int median = 0;

	if(NULL == array || 0 == length)
		return;

	for(; step >= 1; step -=2){
		for(int index = 0; index < step; index ++){
			if((length -1) < (index + step))
				continue;
			else{
				outer = index + step;
				while( (outer + step) <= (length - 1))
					outer += step;
			}

			for(;  outer >= (index + step);  outer -= step){
				for(inner = index; inner <= outer - step; inner += step){
					if(array[inner] >= array[inner + step]){
						median = array[inner];
						array[inner] = array[inner + step];
						array[inner + step] = median;
					}
				}
			}
		}
	}
}






















  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值