最近学习了下java,感觉java在基本语法上与C++非常相似。作为练习,我用java实现了冒泡排序、选择排序、插入排序、基尔排序、快速排序、堆排序、计数排序、合并排序。

以下为实现代码:

public class Sort{
public void print_arr(int[] arr){
int len = arr.length;
for (int i = 0; i < len; i++){
System.out.print("" + arr[i] + " ");
}
System.out.println("");
} public int[] dup_arr(int[] arr){
int len = arr.length;
int re[] = new int[len];
for (int i = 0; i < len; i++){
re[i] = arr[i];
}
return re;
} public int[] bubble(int[] arr){
int dup[] = this.dup_arr(arr);
int len = dup.length;
int tmp = 0;
for (int i = 0; i < len; i++){
for (int j = 0; j < len - 1 - i; j++){
if (dup[j] < dup[j+1]){
tmp = dup[j];
dup[j] = dup[j+1];
dup[j+1] = tmp;
}
}
}
return dup;
} public int[] selection(int[] arr){
int dup[] = this.dup_arr(arr);
int len = dup.length;
int tmp = 0;
int max = 0;
for (int i = 0; i < len; i++){
max = i;
for (int j = i + 1; j < len; j++){
if (dup[j] > dup[max]){
max = j;
}
}
tmp = dup[i];
dup[i] = dup[max];
dup[max] = tmp;
} return dup;
} public int[] insertion(int[] arr){
int dup[] = this.dup_arr(arr);
for (int i = 1; i < dup.length; i++){
int key = dup[i];
int j = i - 1;
while (j >= 0 && dup[j] < key){
dup[j + 1] = dup[j];
j--;
}
dup[j + 1] = key;
}
return dup;
} public int[] shell(int[] arr, int step){
int dup[] = this.dup_arr(arr);
while (step > 0){
//insertion sorting
for (int i = step; i < dup.length; i += step){
int j = i - step;
int key = dup[i];
while (j >= 0 && dup[j] < key){
dup[j + step] = dup[j];
j -= step;
}
dup[j + step] = key;
}
step = step / 2;
}
return dup;
} public void quick(int[] dup, int leftpoint, int rightpoint){
if (leftpoint >= rightpoint){
return;
}
int key = dup[rightpoint];
int left = leftpoint;
int right = rightpoint;
while (true){
while (left < right && dup[left] >= key){
left++;
}
while (left < right && dup[right] <= key){
right--;
}
int tmp = 0;
if (left >= right){
tmp = dup[right];
dup[right] = key;
dup[rightpoint] = tmp;
break;
}
tmp = dup[right];
dup[right] = dup[left];
dup[left] = tmp;
}
this.quick(dup, leftpoint, left - 1);
this.quick(dup, left + 1, rightpoint);
} //min heap
public int micro_adjust(int[] arr, int i, int last){
if (2 * i + 1 > last){
return i;
} int max = arr[i] < arr[2 * i + 1] ? i : (2 * i + 1);
if (2 * i + 2 > last){
return max;
} max = arr[max] < arr[2 * i + 2] ? max : (2 * i + 2);
if (max != i){
int tmp = arr[i];
arr[i] = arr[max];
arr[max] = tmp;
} return max;
}
//part of heap sorting. build a min heap
public void build_heap(int[] arr, int last){
int mid = (last + 1) / 2 - 1;
for (int i = mid; i >= 0; i--){
int tmp = micro_adjust(arr, i, last);
//System.out.print("i: " + i + " tmp: " + tmp + "arr: ");
//this.print_arr(arr);
int flag = i;
while (tmp <= mid && tmp != flag){
flag = tmp;
tmp = micro_adjust(arr, tmp, last);
}
}
return;
}
//part of heap sorting. adjust the left arr
public void adjust_heap(int[] arr, int last){
int tmp = arr[0];
arr[0] = arr[last];
arr[last] = tmp;
this.build_heap(arr, last - 1);
return;
}
//use min heap to sort arr from big to small
public int[] heap(int[] arr){
int dup[] = this.dup_arr(arr);
this.build_heap(dup, dup.length - 1);
for (int i = 0; i < dup.length; i++){
//System.out.print("i: " + i + " arr: ");
//this.print_arr(dup);
adjust_heap(dup, dup.length - 1 - i);
}
return dup;
} public int[] counting(int[] arr){
int min = arr[0];
int max = arr[0];
for (int i = 1; i < arr.length; i++){
min = min < arr[i] ? min : arr[i];
max = max > arr[i] ? max : arr[i];
} int buckets[] = new int[max - min + 1];
int index = 0;
for (int i = 0; i < arr.length; i++){
index = arr[i] - min;
buckets[index]++;
} int res[] = new int[arr.length];
for (int i = 0; i < res.length; i++){
res[i] = -1;
} for (int i = 0; i < arr.length; i++){
index = arr[i] - min;
int cnt = 0;
for (int j = 0; j < index; j++){
cnt += buckets[j];
}
while (res[res.length - 1 - cnt] != -1){
cnt++;
}
res[res.length - 1 - cnt] = arr[i];
}
return res;
} /*Failure: don't know how to build the buckets arr ......
public int[] radix(int[] arr){
int dup[] = this.dup_arr(arr); Queue[] buckets = new Queue[10];
for (int i = 0; i < 10; i++){
buckets[i] = new LinkedList();
} int max = dup[0];
for (int i = 1; i < dup.length; i++){
max = max > dup[i] ? max : dup[i];
} int n = 10;
while (max > 0){
for (int i = 0; i < dup.length; i++){
buckets[dup[i] % n].add(dup[i]);
}
int j = 0;
for (int i = 0; i < 10; i++){
while (!buckets[i].isEmpty()){
dup[j++] = buckets[i].getFirst();
buckets[i].removeFirst();
}
}
max /= 10;
n *= 10;
}
return dup;
}
*/ //part of merge sorting: merge two arr together
public int[] merge(int[] arr1, int[] arr2){
int res[] = new int[arr1.length + arr2.length];
int i = 0;
int j = 0;
int k = 0;
while (i < arr1.length && j < arr2.length){
if (arr1[i] > arr2[j]){
res[k++] = arr1[i++];
}else{
res[k++] = arr2[j++];
}
} while (i < arr1.length){
res[k++] = arr1[i++];
}
while (j < arr2.length){
res[k++] = arr2[j++];
}
return res;
}
//the main part of merge_sort
public int[] merge_sort(int[] arr, int start, int end){
//System.out.println("start: " + start + " end: " + end);
if (end - start < 1){
//System.out.println("end == start");
int tmp[] = {arr[start]};
return tmp;
} int flag = (end - start) / 2;
int res1[] = merge_sort(arr, start, start + flag);
//System.out.println("res1:");
//this.print_arr(res1);
int res2[] = merge_sort(arr, start + flag + 1, end);
//System.out.println("res2:");
//this.print_arr(res2);
int res[] = merge(res1, res2);
//this.print_arr(res);
return res;
} public static void main(String[] args){
int arr[] = {6, 6, 7, 5, 3, 2, 4, 1, 8, 9, 0};
Sort s = new Sort();
System.out.print("The original array: ");
s.print_arr(arr); System.out.print("after bubble sorting: ");
s.print_arr(s.bubble(arr)); System.out.print("after selection sorting: ");
s.print_arr(s.selection(arr)); System.out.print("after insertion sorting: ");
s.print_arr(s.insertion(arr)); System.out.print("after shell sorting: ");
s.print_arr(s.shell(arr, arr.length/2)); System.out.print("after quick sorting: ");
int dup[] = s.dup_arr(arr);
s.quick(dup, 0, dup.length - 1);
s.print_arr(dup); System.out.print("after heap sorting: ");
s.print_arr(s.heap(arr)); System.out.print("after counting sorting: ");
s.print_arr(s.counting(arr)); //failure: because don't know how to define buckets
//System.out.print("after radix sorting: ");
//s.print_arr(s.radix(arr)); //failure: because don't know how to define buckets
//System.out.print("after buckets sorting: ");
//s.print_arr(s.buckets(arr)); System.out.print("after merge sorting: ");
dup = s.dup_arr(arr);
s.print_arr(s.merge_sort(dup, 0, dup.length - 1));
}
}

常见排序算法及其java实现的更多相关文章

  1. 常见排序算法(附java代码)

    常见排序算法与java实现 一.选择排序(SelectSort) 基本原理:对于给定的一组记录,经过第一轮比较后得到最小的记录,然后将该记录与第一个记录的位置进行交换:接着对不包括第一个记录以外的其他 ...

  2. 常见排序算法总结 -- java实现

    常见排序算法总结 -- java实现 排序算法可以分为两大类: 非线性时间比较类排序:通过比较来决定元素间的相对次序,由于其时间复杂度不能突破O(nlogn),因此称为非线性时间比较类排序. 线性时间 ...

  3. 常见排序算法(java实现)

    常见排序算法介绍 冒泡排序 代码: public class BubbleSort { public static void sort(int[] array) { int tValue; for ( ...

  4. 几种常见排序算法之Java实现(插入排序、希尔排序、冒泡排序、快速排序、选择排序、归并排序)

    排序(Sorting) 是计算机程序设计中的一种重要操作,它的功能是将一个数据元素(或记录)的任意序列,重新排列成一个关键字有序的序列. 稳定度(稳定性)一个排序算法是稳定的,就是当有两个相等记录的关 ...

  5. 几种常见排序算法的java实现

    一.几种常见的排序算法性能比較 排序算法 最好时间 平均时间 最坏时间 辅助内存 稳定性 备注 简单选择排序 O(n^2) O(n^2) O(n^2) O(1) 不稳定 n小时较好 直接插入排序 O( ...

  6. 常见排序算法及Java实现

    先上个总图↓: ①.直接插入排序 插入排序(Insertion Sort)的算法描述是一种简单直观的排序算法.它的工作原理是通过构建有序序列,对于未排序数据,在已排序序列中从后向前扫描,找到相应位置并 ...

  7. 六种常见排序算法的java实现

    package edu.cn.ysw; //八种排序算法的实现与效率分析 /* * 内排序的种类: * 1.插入排序:直接插入排序.希尔排序. * 2.选择排序:简单选择排序.堆排序. 3.交换排序: ...

  8. 常见排序算法题(java版)

    常见排序算法题(java版) //插入排序:   package org.rut.util.algorithm.support;   import org.rut.util.algorithm.Sor ...

  9. Java基础语法(8)-数组中的常见排序算法

    title: Java基础语法(8)-数组中的常见排序算法 blog: CSDN data: Java学习路线及视频 1.基本概念 排序: 是计算机程序设计中的一项重要操作,其功能是指一个数据元素集合 ...

随机推荐

  1. 【HDOJ】2242 考研路茫茫——空调教室

    tarjan缩点,然后树形dp一下可解.重点是重边的处理. /* 2242 */ #include <iostream> #include <sstream> #include ...

  2. HTML5学习(四)---Canvas绘图

    参考教程地址:http://www.w3school.com.cn/html5/html_5_canvas.asp canvas 元素用于在网页上绘制图形. 什么是 Canvas? HTML5 的 c ...

  3. hdu4638Group

    http://acm.hdu.edu.cn/showproblem.php?pid=4638 求某一区间所包含的连续的段 对于乱序的数 到了i这个数所包含的段数 首先把这个数看作单独的段 再看一下前面 ...

  4. MySql命令的基本操作

    MySQL的基本命令: 登录:mysql  -h -u root -p password:*****; 例如:mysql -h127.0.0.1 -uroot -p 增加一个用户: grant all ...

  5. [转] web.xml文件详解

    转自:http://www.cnblogs.com/hellojava/archive/2012/12/28/2835730.html 前言:一般的web工程中都会用到web.xml,web.xml主 ...

  6. 判断String为空

    1.  et_string.equals("")|| et_string==null 2.  ""用equal.null用== TextUtils.isEmpt ...

  7. html的视频插件 (转)

         1)jMedia Element是一个基于jQuery/jQuery UI实现的HTML5音频/视频开发工具包.提供非常多的功能来控制页面中的音频和视频内容.当旧的浏览器不兼容HTML5时, ...

  8. Logminer实战

    相信许多DBA同学都曾遇到过这种情况,由于各种各样的原因,必须对数据库做不完全恢复:但又不确定应该恢复到哪个时间点或SCN才合适,因而反复的执行不完全恢复,悲剧掉了一地,中枪的有木有?温馨提示下,在生 ...

  9. 【转】Effective-Objective-C-读书笔记-Item-4-如何正确定义常量 -- 不错

    原文网址:http://tutuge.me/2015/03/11/Effective-Objective-C-%E8%AF%BB%E4%B9%A6%E7%AC%94%E8%AE%B0-Item-4-% ...

  10. AngularJS with MVC4 CRUD

    CRUD using MVC Web API and AngularJS In this article I am going to demonstrate about how can we crea ...