能仔练习1----一次失败的二分排序

因为最近要准备头条和腾讯的面试,开始刷算法,可是自己还是练得太少,刷算法效率太低.不过无所谓了,每刷一道,就比以前的自己厉害一点.

今天的主题是插入排序,.这么简单的排序,却困扰了我很久.首先说一下理解

插入排序的原理就是,首先认定第一个元素是有序的,然后从第二个元素开始,往第一个元素合适的位置插(大于=放在后面,小于交换位置,放在前面)–>所以它是稳定的(遇到相等的不调整位置).
然后第一次插入就导致了一个后果—>前面两个元素都有序了,接着我们从第三个元素开始插入,从第二个元素开始,依次与第三个元素比较,插入到最合适的位置(即插入到刚好小于哪个元素的位置)
这样,循环N-1次(因为是从第二个元素开始的),就完成了N-1个元素的插入,完成了有序

接下来看代码,普通的实现

void swap(int &a,int &b)
{
   
	int temp=a;
	a=b;
	b=temp;
}
void insert(int *arr,int n)
{
   
	if(arr==NULL||n<2) 
		return;
	for(int j=
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值