java 实现排序
package com.cjs.sort; /**
* 此类用来提供针对整数的各种排序算法
*
* @author S
* @version 1.0
*/
public class MySort { /**
* 冒泡排序来实现一系列整数的升序排列,改变了传入的数组
*
* @param a
* 传入的整形数组,对其进行排序的目标数组
* @return void
*/
public static void bubbleSort(int a[]) { int n = a.length;
for (int i = 1; i <= n - 1; i++) {
for (int j = 0; j < n - i; j++) {
if (a[j] > a[j + 1]) {
int t = a[j];
a[j] = a[j + 1];
a[j + 1] = t;
}
}
} } /**
* 选择排序来实现一系列整数的升序排列,改变了传入的数组
*
* @param a
* 传入的整形数组,对其进行排序的目标数组
* @return void
*/
public static void selectSort(int[] a){ int n = a.length; for(int i = 0; i < n; i++){
int x = a[i], k = i;
for(int j = i+1; j < n; j++){
if(a[j] < x){
x = a[j];
k = j;
}
} a[k] = a[i];
a[i] = x;
} } /**
* 插入排序来实现一系列整数的升序排列,改变了传入的数组
*
* @param a
* 传入的整形数组,对其进行排序的目标数组
* @return void
*/
public static void insertSort(int[] a){ int n = a.length; for(int i = 1; i < n; i++){
int x = a[i],k = i;
for(int j = i-1; j >= 0; j--){
if(a[j] > x){
a[j+1] = a[j];
k = j;
}
}
a[k] = x;
} } static int[] temp = new int[100 * 100]; // 归并排序所用到的临时数组 /**
* 归并排序来实现一系列整数的升序排列,改变了传入的数组,所排数组的大小不能超过10000
*
* @param a
* 传入的整形数组,对其进行排序的目标数组
* @param left
* 传入数组的左边界下标
* @param right
* 传入数组的右边界下标
* @return void
*/
public static void mergeSort(int a[], int left, int right) { // 至少有两个元素,也是递归的结束条件
if (left < right) {
int mid = (left + right) / 2;
mergeSort(a, left, mid);
mergeSort(a, mid + 1, right);
// 合并到临时数组temp
Merge(a, temp, left, mid, right);
// 复制回数组a
Copy(a, temp, left, right);
} } /**
* 归并排序中的合并操作,将二分后的数组按升序排列
*
* @param a
* 传入的数组
* @param t
* 要合并到的临时数组
* @param left
* 传入数组的左边界下标
* @param mid
* 传入数组的中间下标
* @param right
* 传入数组的右边界下标
* @return void
*/
private static void Merge(int a[], int t[], int left, int mid, int right) { // 合并c[1:m]和c[m+1:r]到d[l,r]
int i = left, j = mid + 1, k = left;
// 两表中元素比较,类似于打擂台,大的复制到临时数组中
while (i <= mid && j <= right) {
if (a[i] < a[j]) {
t[k++] = a[i++];
} else {
t[k++] = a[j++];
}
} // 若前一个子序列剩余,则直接复制入临时数组
if (i > mid) {
for (int q = j; q <= right; q++)
t[k++] = a[q];
}
// 后一个子序列
else {
for (int q = i; q <= mid; q++)
t[k++] = a[q];
} } /**
* 归并排序中的复制操作,将数据从临时数组中复制到传入的原数组
*
* @param a
* 传入的数组
* @param t
* 保存数据的临时数组
* @param left
* 传入数组的左边界下标
* @param right
* 传入数组的右边界下标
* @return void
*/
private static void Copy(int a[], int t[], int left, int right) { for (int i = left; i <= right; i++)
a[i] = t[i]; } /**
* 快速排序来实现一系列整数的升序排列,改变了传入的数组
*
* @param a
* 传入的整形数组,对其进行排序的目标数组
* @param left
* 传入数组的左边界下标
* @param right
* 传入数组的右边界下标
* @return void
*/
public static void quickSort(int a[], int left, int right) { if (left < right) {
int x = Partition(a, left, right);
quickSort(a, left, x - 1);
quickSort(a, x + 1, right);
} } /**
* 快速排序中用来对元素进行划分,基准元素为a[left]
*
* @param a
* 传入的整形数组,对其进行排序的目标数组
* @param left
* 传入数组的左边界下标
* @param right
* 传入数组的右边界下标
* @return i 划分后基准元素所处位置的下标
*/
private static int Partition(int[] a, int left, int right) { int x = a[left];
int i = left, j = right; while (i < j) { while (i < j && a[j] >= x)
j--;
if (i < j) {
a[i] = a[j];
i++;
} while (i < j && a[i] < x)
i++;
if (i < j) {
a[j] = a[i];
j--;
} }
a[i] = x; return i;
} }
泛型实现:
package com.cjs.alogrithm; /**
* 此类采用泛型方法来提供对各种类型数据的各种排序算法
*
* @author S
* @version 1.0
*/
public class MySort { /**
* 冒泡排序来实现一系列数据的升序排列,改变了传入的数组
*
* @param a
* 传入的存储数据的数组,对其进行排序的目标数组
* @return void
*/
public static <T extends Comparable<T>> void bubbleSort(T a[]) { int n = a.length;
for (int i = 1; i <= n - 1; i++) {
for (int j = 0; j < n - i; j++) {
if ((a[j]).compareTo(a[j + 1]) > 0) {
T t = a[j];
a[j] = a[j + 1];
a[j + 1] = t;
}
}
} } /**
* 选择排序来实现一系列数据的升序排列,改变了传入的数组
*
* @param a
* 传入的存储数据数组,对其进行排序的目标数组
* @return void
*/
public static <T extends Comparable<T>> void selectSort(T[] a) { int n = a.length; for (int i = 0; i < n; i++) {
T x = a[i];
int k = i;
for (int j = i + 1; j < n; j++) {
if (a[j].compareTo(x) < 0) {
x = a[j];
k = j;
}
} a[k] = a[i];
a[i] = x;
} } /**
* 插入排序来实现一系列数据的升序排列,改变了传入的数组
*
* @param a
* 传入的存储数据的数组,对其进行排序的目标数组
* @return void
*/
public static <T extends Comparable<T>> void insertSort(T[] a) { int n = a.length; for (int i = 1; i < n; i++) {
T x = a[i];
int k = i;
for (int j = i - 1; j >= 0; j--) {
if (a[j].compareTo(x) > 0) {
a[j + 1] = a[j];
k = j;
}
}
a[k] = x;
} } /**
* 归并排序来实现一系列数据的升序排列,改变了传入的数组,需要额外提供一个临时数组来辅助排序
*
* @param a
* 传入的存储数据的数组,对其进行排序的目标数组
* @param left
* 传入数组的左边界下标
* @param right
* 传入数组的右边界下标
* @return void
*/
public static <T extends Comparable<T>> void mergeSort(T a[], T temp[],
int left, int right) { // 至少有两个元素,也是递归的结束条件
if (left < right) {
int mid = (left + right) / 2;
mergeSort(a, temp, left, mid);
mergeSort(a, temp, mid + 1, right);
// 合并到临时数组temp
Merge(a, temp, left, mid, right);
// 复制回数组a
Copy(a, temp, left, right);
} } /**
* 归并排序中的合并操作,将二分后的数组按升序排列
*
* @param a
* 传入的数组
* @param t
* 要合并到的临时数组
* @param left
* 传入数组的左边界下标
* @param mid
* 传入数组的中间下标
* @param right
* 传入数组的右边界下标
* @return void
*/
private static <T extends Comparable<T>> void Merge(T a[], T t[], int left,
int mid, int right) { // 合并c[1:m]和c[m+1:r]到d[l,r]
int i = left, j = mid + 1, k = left;
// 两表中元素比较,类似于打擂台,大的复制到临时数组中
while (i <= mid && j <= right) {
if (a[i].compareTo(a[j]) < 0) {
t[k++] = a[i++];
} else {
t[k++] = a[j++];
}
} // 若前一个子序列剩余,则直接复制入临时数组
if (i > mid) {
for (int q = j; q <= right; q++)
t[k++] = a[q];
}
// 后一个子序列
else {
for (int q = i; q <= mid; q++)
t[k++] = a[q];
} } /**
* 归并排序中的复制操作,将数据从临时数组中复制到传入的原数组
*
* @param a
* 传入的数组
* @param t
* 保存数据的临时数组
* @param left
* 传入数组的左边界下标
* @param right
* 传入数组的右边界下标
* @return void
*/
private static <T extends Comparable<T>> void Copy(T a[], T t[], int left,
int right) { for (int i = left; i <= right; i++)
a[i] = t[i]; } /**
* 快速排序来实现一系列数据的升序排列,改变了传入的数组
*
* @param a
* 传入的存储数据的数组,对其进行排序的目标数组
* @param left
* 传入数组的左边界下标
* @param right
* 传入数组的右边界下标
* @return void
*/
public static <T extends Comparable<T>> void quickSort(T a[], int left,
int right) { if (left < right) {
int x = Partition(a, left, right);
quickSort(a, left, x - 1);
quickSort(a, x + 1, right);
} } /**
* 快速排序中用来对元素进行划分,基准元素为a[left]
*
* @param a
* 传入的存储数据的数组,对其进行排序的目标数组
* @param left
* 传入数组的左边界下标
* @param right
* 传入数组的右边界下标
* @return i 划分后基准元素所处位置的下标
*/
private static <T extends Comparable<T>> int Partition(T[] a, int left,
int right) { T x = a[left];
int i = left, j = right; while (i < j) { while (i < j && a[j].compareTo(x) >= 0)
j--;
if (i < j) {
a[i] = a[j];
i++;
} while (i < j && a[i].compareTo(x) < 0)
i++;
if (i < j) {
a[j] = a[i];
j--;
} }
a[i] = x; return i;
} }
java 实现排序的更多相关文章
- Java常用排序算法+程序员必须掌握的8大排序算法+二分法查找法
Java 常用排序算法/程序员必须掌握的 8大排序算法 本文由网络资料整理转载而来,如有问题,欢迎指正! 分类: 1)插入排序(直接插入排序.希尔排序) 2)交换排序(冒泡排序.快速排序) 3)选择排 ...
- Java 常用排序算法/程序员必须掌握的 8大排序算法
Java 常用排序算法/程序员必须掌握的 8大排序算法 分类: 1)插入排序(直接插入排序.希尔排序) 2)交换排序(冒泡排序.快速排序) 3)选择排序(直接选择排序.堆排序) 4)归并排序 5)分配 ...
- java 集合排序(转)
Java API针对集合类型排序提供了两种支持:java.util.Collections.sort(java.util.List)java.util.Collections.sort(java.ut ...
- java:高速排序算法与冒泡排序算法
Java:高速排序算法与冒泡算法 首先看下,冒泡排序算法与高速排序算法的效率: 例如以下的是main方法: /** * * @Description: * @author:cuiyaon ...
- java常见排序方法
1.java常用排序方法 1) 选择排序 原理:a. 将数组中的每个元素,与第一个元素比较 如果这个元素小于第一个元素, 就将这个 两个元素交换. ...
- java希尔排序
java希尔排序 1.基本思想: 希尔排序也成为"缩小增量排序",其基本原理是,现将待排序的数组元素分成多个子序列,使得每个子序列的元素个数相对较少,然后对各个子序列分别进行直接插 ...
- Java八大排序算法
Java八大排序算法: package sort; import java.util.ArrayList; import java.util.Arrays; import java.util.List ...
- Java常用排序算法及性能测试集合
测试报告: Array length: 20000 bubbleSort : 573 ms bubbleSortAdvanced : 596 ms bubbleSortAdvanced2 : 583 ...
- java 集合排序
Java API针对集合类型排序提供了两种支持:java.util.Collections.sort(java.util.List)java.util.Collections.sort(java.ut ...
- Java各种排序算法
Java各种排序算法详解 排序大的分类可以分为两种:内排序和外排序.在排序过程中,全部记录存放在内存,则称为内排序,如果排序过程中需要使用外存,则称为外排序.下面讲的排序都是属于内排序. 内排序有 ...
随机推荐
- iOS 语音识别使用讯飞报错
You must rebuild it with bitcode enabled(Xcode setting ENABLE_BITCODE), obtain an updated library fr ...
- ASIHttpRequest:创建队列、下载请求、断点续传、解压缩
ps:本文转载自网络:http://ryan.easymorse.com/?p=12 感谢作者 工程完整代码下载地址:RequestTestDownload1 可完成: 下载指定链接的zip压缩文件 ...
- Netty实例-简单的服务端-client实现,凝视具体
书籍推荐: 实例代码 :http://download.csdn.net/detail/jiangtao_st ...
- C++刷称号——2707: 素数与要素
Description 从键盘输入的随机整数n,如果n不是质数,然后计算n所有的因素(不含1).例如,对于16,出口2,4,8:否则输出"It is a prime number." ...
- HDU 1027 Ignatius and the Princess II 选择序列题解
直接选择序列的方法解本题,可是最坏时间效率是O(n*n),故此不能达到0MS. 使用删除优化,那么就能够达到0MS了. 删除优化就是当须要删除数组中的元素为第一个元素的时候,那么就直接移动数组的头指针 ...
- JS基础函数
函数是由事件驱动的或者当它被调用时执行的可重复使用的代码块 <script> function demo(){ var a = 10; var b = 25; var sum = a + ...
- 数据泵导出/导入Expdp/impdp
一下转自 http://blog.csdn.net/jionjionyoushen/article/details/6789686 数据泵导出/导入Expdp/impdp Oracle 10g引入了D ...
- 【1】Laravel5.1 安装
1.安装composer http://www.phpcomposer.com/ 这个是中文网址里边有教程,但是由于被墙的缘故,可以通过下边这个链接下载Windows安装包 http://docs.p ...
- ubuntu中安装jdk
1.下载jdk压缩包: http://download.oracle.com/otn-pub/java/jdk/7u55-b13/jdk-7u55-linux-x64.tar.gz 2.解压缩jdk ...
- [Mugeda HTML5技术教程之12]制作跨屏互动应用
mugeda动画平台还可以用来制作跨屏互动的动画应用,比如在PC端的大屏幕上显示动画的主界面,同时会显示出供手机扫描的二维码,手机扫描后会在手机上显示手机端动画界面.通过手机就可以和PC端的显示界面跨 ...