Java排序算法汇总大全
更新时间:2023-11-12 06:04:01 阅读量: 教育文库 文档下载
package com.softeem.jbs.lesson4;
import java.util.Random; /**
* 排序测试类 *
* 排序算法的分类如下:
* 1.插入排序(直接插入排序、折半插入排序、希尔排序);
* 2.交换排序(冒泡泡排序、快速排序);
* 3.选择排序(直接选择排序、堆排序);
* 4.归并排序;
* 5.基数排序。 *
* 关于排序方法的选择:
* (1)若n较小(如n≤50),可采用直接插入或直接选择排序。
* 当记录规模较小时,直接插入排序较好;否则因为直接选择移动的记录数少于直接插人,应选直接选择排序为宜。
* (2)若文件初始状态基本有序(指正序),则应选用直接插人、冒泡或随机的快速排序为宜;
* (3)若n较大,则应采用时间复杂度为O(nlgn)的排序方法:快速排序、堆排序或归并排序。 * */
public class SortTest {
/**
* 初始化测试数组的方法
* @return 一个初始化好的数组
*/
public int[] createArray() {
Random random = new Random();
int[] array = new int[10];
for (int i = 0; i < 10; i++) {
array[i] = random.nextInt(100) - random.nextInt(100);//生成两个随机数相减,保证生成的数中有负数
}
System.out.println(\原始序列==========\
printArray(array);
return array;
}
/**
* 打印数组中的元素到控制台
* @param source
*/
public void printArray(int[] data) {
for (int i : data) {
System.out.print(i + \
}
System.out.println();
}
/**
* 交换数组中指定的两元素的位置
* @param data
* @param x
* @param y
*/
private void swap(int[] data, int x, int y) {
int temp = data[x];
data[x] = data[y];
data[y] = temp;
}
/**
* 冒泡排序----交换排序的一种
* 方法:相邻两元素进行比较,如有需要则进行交换,每完成一次循环就将最大元素排在最后(如从小到大排序),下一次循环是将其他的数进行类似操作。
* 性能:比较次数O(n^2),n^2/2;交换次数O(n^2),n^2/4
*
* @param data 要排序的数组
* @param sortType 排序类型
* @return
*/
public void bubbleSort(int[] data, String sortType) {
if (sortType.equals(\正排序,从小排到大
//比较的轮数
for (int i = 1; i < data.length; i++) {
//将相邻两个数进行比较,较大的数往后冒泡
for (int j = 0; j < data.length - i; j++) {
if (data[j] > data[j + 1]) {
//交换相邻两个数
swap(data, j, j + 1);
}
}
}
} else if (sortType.equals(\倒排序,从大排到小
//比较的轮数
for (int i = 1; i < data.length; i++) {
//将相邻两个数进行比较,较大的数往后冒泡
for (int j = 0; j < data.length - i; j++) {
if (data[j] < data[j + 1]) {
//交换相邻两个数
swap(data, j, j + 1);
}
}
}
} else {
System.out.println(\您输入的排序类型错误!\
}
printArray(data);//输出冒泡排序后的数组值
}
/**
* 直接选择排序法----选择排序的一种
* 方法:每一趟从待排序的数据元素中选出最小(或最大)的一个元素, 顺序放在已排好序的数列的最后,直到全部待排序的数据元素排完。
* 性能:比较次数O(n^2),n^2/2
* 交换次数O(n),n
* 交换次数比冒泡排序少多了,由于交换所需CPU时间比比较所需的CUP时间多,所以选择排序比冒泡排序快。
* 但是N比较大时,比较所需的CPU时间占主要地位,所以这时的性能和冒泡排序差不太多,但毫无疑问肯定要快些。
*
*/
public int binarySearch(int[] dataset, int data) {
int beginIndex = 0;
int endIndex = dataset.length - 1;
int midIndex = -1;
if (data < dataset[beginIndex] || data > dataset[endIndex]
|| beginIndex > endIndex)
return -1;
while (beginIndex <= endIndex) {
midIndex = (beginIndex + endIndex) >>> 1; //相midIndex = (beginIndex + endIndex) / 2,但是效率会高些
if (data < dataset[midIndex]) {
endIndex = midIndex - 1;
} else if (data > dataset[midIndex]) {
beginIndex = midIndex + 1;
} else {
return midIndex;
}
}
return -1;
}
于
当 public static void main(String[] args) {
SortTest sortTest = new SortTest();
int[] array = sortTest.createArray();
System.out.println(\冒泡排序后(正序)==========\
sortTest.bubbleSort(array, \
System.out.println(\冒泡排序后(倒序)==========\
sortTest.bubbleSort(array, \
array = sortTest.createArray();
System.out.println(\倒转数组后==========\
sortTest.reverse(array);
array = sortTest.createArray();
System.out.println(\选择排序后(正序)==========\
sortTest.selectSort(array, \
System.out.println(\选择排序后(倒序)==========\
sortTest.selectSort(array, \
array = sortTest.createArray();
System.out.println(\插入排序后(正序)==========\
sortTest.insertSort(array, \
System.out.println(\插入排序后(倒序)==========\
sortTest.insertSort(array, \
array = sortTest.createArray();
System.out.println(\快速排序后(正序)==========\
sortTest.quickSort(array, \
sortTest.printArray(array);
System.out.println(\快速排序后(倒序)==========\
sortTest.quickSort(array, \
sortTest.printArray(array);
System.out.println(\数组二分查找==========\
System.out.println(\您要找的数在第\
+ \个位子。(下标从0计算)\
} }
正在阅读:
Java排序算法汇总大全11-12
去农村作文400字06-25
课程设计:基于Matlab的数字滤波器设计及其对语音信号的应用09-19
9装配生产工艺知识03-18
2009年天津市中考物理试卷12-20
我家乡的清江河作文400字07-09
2019猪年新年祝福语 简短暖心02-23
- exercise2
- 铅锌矿详查地质设计 - 图文
- 厨余垃圾、餐厨垃圾堆肥系统设计方案
- 陈明珠开题报告
- 化工原理精选例题
- 政府形象宣传册营销案例
- 小学一至三年级语文阅读专项练习题
- 2014.民诉 期末考试 复习题
- 巅峰智业 - 做好顶层设计对建设城市的重要意义
- (三起)冀教版三年级英语上册Unit4 Lesson24练习题及答案
- 2017年实心轮胎现状及发展趋势分析(目录)
- 基于GIS的农用地定级技术研究定稿
- 2017-2022年中国医疗保健市场调查与市场前景预测报告(目录) - 图文
- 作业
- OFDM技术仿真(MATLAB代码) - 图文
- Android工程师笔试题及答案
- 生命密码联合密码
- 空间地上权若干法律问题探究
- 江苏学业水平测试《机械基础》模拟试题
- 选课走班实施方案
- 算法
- 汇总
- 排序
- 大全
- Java
- 仪器分析网上作业1、2、3(中南大学)
- 高素质技能型人才培养模式研究与实践
- 中国太阳能利用调研报告目录
- 教务工作在校园文化建设中的任务及实现途径(校长参考)
- 第四批申报书空白表
- 307医院综合楼施工组织设计
- 我国土地征用问题研究
- 汽车转向盘摆振故障分析
- 劝返制度
- 材料力学(金忠谋)第六版答案第02章
- 骆驼祥子女性人物浅析 - 中学文学名篇深度解读 期末论文作业
- 泗阳县粮食局安全生产制度
- 讲道学
- 新城市主义及精明增长之解读 - 唐相龙
- 国内外资产证券化运作模式及对我国发展资产证券化的思考
- 国家规划矿区划分及开拓方式
- 边坡支护监理实施细则
- 通州区2017-2018学年第一学期九年级期中学业水平质量检测数学试卷(含答案)
- 地理教材分析
- 国电和风风电开发有限公司风电场设计服务招标评标报告新