网站首页 > java教程 正文
数组排序算法是最常见的算法入门,其中归并排序是通过二分法加上对已排序数组进行合并来达到排序的目的。今天就来讲解下其中的合并已排序数组算法实现方式。
实现一,不断比较两个数组的最小项,将最小项添加到新数组
两个数组已经排好了序,要将其合并,并保持新的排序。那么可以通过不断比较最小项来实现。这是最标准的写法,但需要用到一个新的数组。具体步骤如下:
1、用两个数组的最小项不断进行比较,小的项就添加到新数组中去。
2、小的项已经添加到新数组后,其所在位置就往后挪一位,选取新的最小项。
3、不断遍历两个数组,直到其中一个数组项全部被添加完成为止。
4、将还没有比较完成的数组项,也就是大的数组项,依次添加到新数组中。
实现二,从一个数组中依次选取最小项插入到另外的数组
这个方法就是从一个数组中依次选择最小项,然后将该项插入到另外数组对应的位置上,类似插入排序。具体步骤如下:
1、遍历其中一个数组,从里逐个选择最小项。
2、将最小项插入到第二项的数组中去。
3、插入时自后往前逐个遍历第二项数组,将插入位置后面的项整体移动一位。
4、再将插入项放到空处的位置中。
验证
可以看到验证结果符合预期。您还有哪些方法,欢迎发表看法。谢谢!
猜你喜欢
- 2024-10-22 Java几种排序方式(java排序的方法有哪些)
- 2024-10-22 Java排序算法——归并排序(Merge Sort)
- 2024-10-22 Java 集合中的排序算法浅析(java集合排序工具类)
- 2024-10-22 数组排序与二分查找法(二分查找排序树)
- 2024-10-22 LeetCode基础算法题第85篇:求有序数组的平方再排序
- 2024-10-22 Java中Arrays的两种排序方法(sort和parallelSort)比较
- 2024-10-22 深入理解Java中Comparable和Comparator排序
- 2024-10-22 Java常见知识之冒泡排序#冒泡排序
- 2024-10-22 Java数组之Arrays方法(java array数组)
- 2024-10-22 常用集合的排序方法——Java进阶知识讲义系列(七)
你 发表评论:
欢迎- 最近发表
- 标签列表
-
- java反编译工具 (77)
- java反射 (57)
- java接口 (61)
- java随机数 (63)
- java7下载 (59)
- java数据结构 (61)
- java 三目运算符 (65)
- java对象转map (63)
- Java继承 (69)
- java字符串替换 (60)
- 快速排序java (59)
- java并发编程 (58)
- java api文档 (60)
- centos安装java (57)
- java调用webservice接口 (61)
- java深拷贝 (61)
- 工厂模式java (59)
- java代理模式 (59)
- java.lang (57)
- java连接mysql数据库 (67)
- java重载 (68)
- java 循环语句 (66)
- java反序列化 (58)
- java时间函数 (60)
- java是值传递还是引用传递 (62)
本文暂时没有评论,来添加一个吧(●'◡'●)