主要排序算法的Java实现
最近温习算法,花点时间写了点代码验证下,在这里做个存档。
package com.chrischeng.hacker; import java.util.*; /**
* Created by Yexin on 2016/11/4.
*/ //Complete the code
public class Solution
{
private final static int ARRAYSIZE = 50;
private final static int ARRAYRANGE = ARRAYSIZE * 2; // 通过随机数发生器生成一个指定大小的随机数组
public static int[] createArray(int size){
int []retArray = new int [size];
Random random = new Random();
for(int i = 0;i < size;i++)
retArray[i] = random.nextInt(ARRAYRANGE);
return retArray;
} // 打印指定数组
public static void printArray(int []arr){
for(int a : arr)
System.out.print(a + " ");
System.out.println();
} // 交换数组中指定序号的元素值
public static void swap(int[] arr, int i, int j ){
if(i >= arr.length || j >= arr.length)
return;
else{
int temp = arr[i];
arr[i] = arr[j];
arr[j] = temp;
}
} // 使用带有标志位的冒泡排序
public static void bubbleSort(int []arr){
int len = arr.length;
boolean flag = false;
for(int i = 0; i < len - 1; i++){
for(int j = i + 1; j < len;j++){
if(arr[i] > arr[j]) {
swap(arr, i, j);
flag = true;
}
}
if(flag == false)
break;
}
} // 直接插入排序
public static void insertionSort(int []arr){
int len = arr.length, i = 1, j;
for(; i < len; i++){
int temp = arr[i];
if(arr[i - 1] > arr[i]){
j = i - 1;
while(j >= 0 && arr[j] > temp) {
arr[j+1] = arr[j];
j--;
}
arr[j+1] = temp;
}
}
} // Shell排序(本质上就是分治法的直接插入排序)
public static void shellSort(int []arr){
int len = arr.length, gap, i, j;
for(gap = len/2; gap > 0; gap /= 2){
for(i = gap;i < len; i++){
if(arr[i] < arr[i -gap]){
int temp = arr[i];
j = i - gap;
while(j >= 0 && arr[j] > temp){
arr[j+gap] = arr[j];
j -= gap;
}
arr[j+gap] = temp;
}
}
}
} // 快速排序
public static void quickSort(int []arr, int l, int r){
if(l < r) {
int i = l, j = r, base = arr[r];
while (i < j) {
// 由左至右遍历,找到第一个大于中轴的元素
while (i < j && arr[i] < base)
i++;
// 如果i和j没有交叉且找到了第一个大于中轴的元素(index为i),则将它的值存放在j的位置,而j位置的值存放在base中
if (i < j)
arr[j--] = arr[i];
// 从右到左遍历,找到第一个小于中轴的元素
while (i < j && arr[j] > base)
j--;
// 如果i和j没有交叉且找到了第一个小于中轴的元素,则将他的值存放在上一步中index-i的位置上
if (i < j)
arr[i++] = arr[j];
}
// 上面的遍历完成后,i左侧都是小于base的元素,右侧都是大于base的元素,base作为中值存放在index=i的位置上,并不参与下次排序
arr[i] = base;
// 分别对数组左右侧进行递归排序
quickSort(arr,l,i-1);
quickSort(arr,i+1,r);
}
} // 桶排序
// 本质上其实就是彻底的牺牲空间换取时间的做法
// 适用于数字范围在一定区间内的随机数组
public static void bucketSort(int arr[]){
// 此处之所以使用对象数组,是因为实际情况中存在多个同值元素存在的可能性
ArrayList<Integer> buckets[] = new ArrayList[ARRAYRANGE + 1];
for(int i : arr) {
if (buckets[i] == null)
buckets[i] = new ArrayList<Integer>();
buckets[i].add(new Integer(i));
}
int index = 0;
for(ArrayList<Integer> al : buckets){
if(null != al && al.size() > 0){
for(Integer i : al)
arr[index++] = i;
}
}
} // 基数排序
// 本质上就是按照从低位到高位的桶排序,所以无论随机数组的长度为多大,永远只需要十个桶
public static void radixSort(int arr[]){
} public static void main(String[] args){
int [] arr = createArray(ARRAYSIZE);
printArray(arr);
bucketSort(arr);
printArray(arr);
}
}
主要排序算法的Java实现的更多相关文章
- 常见排序算法(附java代码)
常见排序算法与java实现 一.选择排序(SelectSort) 基本原理:对于给定的一组记录,经过第一轮比较后得到最小的记录,然后将该记录与第一个记录的位置进行交换:接着对不包括第一个记录以外的其他 ...
- 几大排序算法的Java实现
很多的面试题都问到了排序算法,中间的算法和思想比较重要,这边我选择了5种常用排序算法并用Java进行了实现.自己写一个模板已防以后面试用到.大家可以看过算法之后,自己去实现一下. 1.冒泡排序:大数向 ...
- 7种基本排序算法的Java实现
7种基本排序算法的Java实现 转自我的Github 以下为7种基本排序算法的Java实现,以及复杂度和稳定性的相关信息. 以下为代码片段,完整的代码见Sort.java 插入排序 /** * 直接插 ...
- 几种简单的排序算法(JAVA)
几种排序算法(JAVA) 一.代码 package com.hdwang; import java.util.Arrays; /** * Created by admin on 2017/1/20. ...
- 常见排序算法总结 -- java实现
常见排序算法总结 -- java实现 排序算法可以分为两大类: 非线性时间比较类排序:通过比较来决定元素间的相对次序,由于其时间复杂度不能突破O(nlogn),因此称为非线性时间比较类排序. 线性时间 ...
- 几大排序算法的Java实现(原创)
几大排序算法的Java实现 更新中... 注: 该类中附有随机生成[min, max)范围不重复整数的方法,如果各位看官对此方法有什么更好的建议,欢迎提出交流. 各个算法的思路都写在该类的注释中了,同 ...
- 十大经典排序算法(java实现、配图解,附源码)
前言: 本文章主要是讲解我个人在学习Java开发环境的排序算法时做的一些准备,以及个人的心得体会,汇集成本篇文章,作为自己对排序算法理解的总结与笔记. 内容主要是关于十大经典排序算法的简介.原理.动静 ...
- 基本排序算法——冒泡排序java实现
冒泡排序是原理最简单的一种排序算法,具体思想就不多说了,代码如下: eclipse4.3中编译通过 package sort.basic; import java.util.Arrays; publi ...
- 排序算法练习--JAVA(插入、直接选择、冒泡、快速排序、非递归快速排序)
排序算法是数据结构中的经典算法知识点,也是笔试面试中经常考察的问题,平常学的不扎实笔试时候容易出洋相,回来恶补,尤其是碰到递归很可能被问到怎么用非递归实现... package sort; impor ...
- 排序算法(JAVA)
import java.util.Random; /** * 排序测试类 * * 排序算法的分类如下: * 1.插入排序(直接插入排序.折半插入排序.希尔排序): * 2.交换排 ...
随机推荐
- mysql for windows(服务器)上的配置安装--实例
mysql for windows(服务器)上的配置安装 **** 下载 官网网址:https://www.mysql.com/downloads/ 选择左上角Community 再选择MySQL C ...
- django restframework serializer 增加自定义字段
在使用django restframework serializer 序列化在django中定义的model时,有时候我们需要额外在serializer中增加一些model中没有的字段.有两种方法实现 ...
- 分针网—每日分享:HTML解析原理
标准的web前端工程师需要知道 ◎浏览器(或者相应播放器)的渲染/重绘原理 这我得加把劲了.我还真的说的不是很清楚,我就G下,结果不是很多,找到了有一个,就记下来了... 以下部分来自hand ...
- 堆和栈(java内存)
栈内存: 在函数中定义的一些基本类型的变量和对象的引用变量都是在函数的栈内存中分配.当在一段代码块中定义一个变量时,java就在栈中为这个变量分配内存空间,当超过变量的作用域后,java会自动释放掉为 ...
- hdu3336 Count the string kmp+dp
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=3336 很容易想到用kmp 这里是next数组的应用 定义dp[i]表示以s[i]结尾的前缀的总数 那么 ...
- java内存模型6-final
与前面介绍的锁和volatile相比较,对final域的读和写更像是普通的变量访问.对于final域,编译器和处理器要遵守两个重排序规则: 在构造函数内对一个final域的写入,与随后把这个被构造对象 ...
- Java中的Object、T(泛型)、?区别
因为最近重新看了泛型,又看了些反射,导致我对Object.T(以下代指泛型).?产生了疑惑. 我们先来试着理解一下Object类,学习Java的应该都知道Object是所有类的父类,注意:那么这就意味 ...
- Hive的分区操作~~~~~~
一.Hive分区(一).分区概念:为什么要创建分区:单个表数据量越来越大的时候,在Hive Select查询中一般会扫描整个表内容,会消耗很多时间做没必要的工作.有时候只需要扫描表中关心的一部分数据, ...
- Angular环境准备和Angular cli
Angular4.0来了,更小,更快,改动少 接下来为Angular4.0准备环境和学会使用Angular cli项目 1.环境准备: 1)在开始工作之前我们必须设置好开发环境 如果你的机器上还没有安 ...
- 关于Cookie的知识的总结
Cookie的类型 会话cookie和持久cookie 会话cookie是一种临时cookie,它记录了用户访问站点时的设置和偏好,当用户退出浏览器时,会话cookie就会被删除. 持久cookie的 ...