主要排序算法的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.交换排 ...
随机推荐
- selenium IDE的3种下载安装方式
第一种方式: 打开firefox浏览器-----点击右上角-----附加组件----插件----搜索框输入“selenium”-----搜索的结果中下拉到页面尾部,点击“查看全部的37项结果”---进 ...
- PHP的学习记录
这是我的第一次写博客,是一个PHP的初学者,刚刚开始之前是一点儿的都不懂,现在开始通过买些书籍回来学习,废话少说,开始记录笔记吧. 函数:函数的英文名为function,也就是功能的意思,在自定义函数 ...
- OC分类(Category)
Category 分类 ,又称为类别.类目 概念 Category有多种翻译:分类.类别.类目(一般叫分类的多) Category式OC特有的语法,其他语言没有的语法(类似于C#语言中的"扩 ...
- 基于ZKWeb + Angular 4.0的开源管理后台Demo
这是一套基于ZKWeb网页框架和Angular 4.0编写的开源管理后台Demo,实现了前后端分离和模块化开发, 地址是: https://github.com/zkweb-framework/ZKW ...
- redis连接池的使用方法
所需jar:jedis-2.8.0.jar和commons-pool-2-2.3jar Jedis操作步骤如下:1->获取Jedis实例需要从JedisPool中获取:2->用完Jedis ...
- 浅谈RSA加密
RSA背景 在1976年以前,传统的加解密过程是: 1.A采用某种手段对数据进行加密. 2.数据传输到B的手中. 3.B逆向的实施A加密采用的步骤. 4.数据被还原. 这就是所谓的对称加密. 解密和加 ...
- ReentrantLock深入学习
ReentrankLock 分为 非公平锁及公平锁 首先我们看一下它里面有哪些属性: private final Sync sync;Sync 这个类是 ReentrantLock的 一个静态内部类 ...
- while循环 操作列表与字典
1.在列表间移动元素 #!/usr/bin/env python #filename=list.py num1 = [1,3,5,7,9,11,13,15] num2 = [] while num1: ...
- mac下eclipse安装svn插件-subclipse
目前Eclipse最常用的svn插件莫非subclipse,在windows系统下的安装svn client和subclipse比较简单.本文介绍如何在mac安装svn插件和subclipse. 一. ...
- excel vba 实现跨表单(sheet) 搜索 - 显示搜索行记录搜索历史
前两天,一个朋友问我,有没有办法在excel里实现一个表单里是原始数据,在另一个表单里显示搜索到的行,搜索关键词可用~分隔开,并把搜索历史记录下来? 我想了想,用vba实现肯定可以啊,但是我又在想,有 ...