千锋教育-做有情怀、有良心、有品质的职业教育机构

当前位置:首页  >  关于学院  >  技术干货  >  Java技术干货  >  正文

插入排序算法你熟悉吗?

来源:千锋教育
作者:qyf
关键词: 上海java
2022-09-20
分享

插入排序算法你熟悉吗

  通过构建有序序列,对于未排序数据,在已排序序列中从后向前扫描,找到相应的位置并插入。插入排序非常类似于整扑克牌。在开始摸牌时,左手是空的,牌面朝下放在桌上。接着,一次从桌上摸起一张牌,并将它插入到左手一把牌中的正确位置上。为了找到这张牌的正确位置,要将它与手中已有的牌从右到左地进行比较。无论什么时候,左手中的牌都是排好序的。

  如果输入数组已经是排好序的话,插入排序出现最佳情况,其运行时间是输入规模的一个线性函数。如果输入数组是逆序排列的,将出现最坏情况。平均情况与最坏情况一样,其时间代价是(n2)。

public void sort(int arr[]){
for(int i =1; i<arr.length;i++){
//插入的数
int insertVal = arr[i];
//被插入的位置(准备和前一个数比较)
int index = i-1;
//如果插入的数比被插入的数小
while(index>=0&&insertVal<arr[index]){
//将把 arr[index] 向后移动 arr[index+1]=arr[index];
//让 index 向前移动
index--;
}
//把插入的数放入合适位置
arr[index+1]=insertVal;
}
}

声明:本站稿件版权均属千锋教育所有,未经许可不得擅自转载。

相关推荐

  • char和varchar的区别是什么? 如果有两个事务,运行在相同的时间内,执行相同的功能,事务的隔离性确保每一个事务在系统中认为只有自己在使用系统。这种属性称为串行化,为了防止事务操作间的混淆,必须串行化或序列化请求,使得在同一时间仅有一个请求用于同一数据。持久性   一个成功的事务将永久的改变系统的状态。
  • 如何获取当前数据库版本? //MySQL //命令行 mysql -v //查询函数 select version();//Oracle select * from v$version;
  • 除了ReetrantLock,你还接触过JUC并发包中的哪些并发API? Exchanger:用来使两个线程交换数据;总数就是控制并发的数量;Future:接口,FutureTask是它的实现类,配合线程池来一起工作,将任务交给线程池去处理。
  • RabbitMQ中的交换机类型有哪些? Exchange 分发消息时根据类型的不同分发策略有区别,目前共四种类型:direct、fanout、topic、headers 。headers 匹配 AMQP 消息的 header 而不是路由键,此外 headers 交换器和 direct 交换器完全一致,但性能差很多,目前几乎用不到了,所以直接看另外三种类型:
  • 插入排序算法你熟悉吗? 为了找到这张牌的正确位置,要将它与手中已有的牌从右到左地进行比较。如果输入数组已经是排好序的话,插入排序出现最佳情况,其运行时间是输入规模的一个线性函数。如果输入数组是逆序排列的,将出现最坏情况。平均情况与最坏情况一样,其时间代价是(n2)。
  • 冒泡排序算法你熟悉吗? 比较前后相邻的二个数据,如果前面数据大于后面的数据,就将这二个数据交换。这样对数组的第 0 个数据到 N-1 个数据进行一次遍历后,最大的一个数据就“沉”到数组第N-1 个位置。N=N-1,如果 N 不为 0 就重复前面二步,否则排序完成。