Java学习之路——插入排序

插入排序

排序思想:每步将一个待排序的记录,按其数组下标大小插入到前面已经排序的子序列的合适位置(从后向前找到合适位置后),直到全部插入排序完为止。
  排序举例:int a[]= {1,7,2,9,8,4},默认第一个数组元素以排好序,选定第二个开始插入。
第一次排序:选定a[2] = 7排序。
1<7,不交换位置
排序结果:1 7 2 9 8 4

第二次排序:选定a[3] = 2排序。
7>2,交换位置
1<2,不交换位置
排序结果:1 2 7 9 8 4

第三次排序:选定a[4] = 9排序。
7<9,不交换位置
2<9,不交换位置
1<9,不交换位置
排序结果:1 2 7 9 8 4

第四次排序:选定a[5] = 8排序。
9>8,交换位置
7<8,不交换位置
2<8,不交换位置
1<8,不交换位置
排序结果:1 2 7 8 9 4

第五次排序:选定a[6] = 4排序。
9>4,交换位置
8>4,交换位置
7>4,交换位置
2<4,不交换位置
1<4,不交换位置
排序结果:1 2 7 8 9 4
代码实现:

	public static int[] insertSort(int[] data) {
		int temp;	//临时变量
		int j;	//定位比较的数组元素下标
		for (int i = 1; i < data.length; i++) {//默认第一个元素以排好序,从第二个元素开始扫描,共扫描length-1次
			temp = data[i];
			j = i-1;//将data[i]与他的前一位data[i-1]比较
			while(j>=0 && temp<data[j]) {//若小于
				data[j+1] = data[j];//把所有的元素往后推一个
				j--;
			}
			data[j+1] = temp;//最小的元素放到移动后的缺口处
		}
		return data;
	}
	public static void main(String[] args) {//主方法调用
		int a[]= {1,7,2,9,8,4};//定义数组
		int b[]=insertSort(a);//调用方法
		for (int num : b) {
			System.out.println(num);
		}
	}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值