最近温习算法,花点时间写了点代码验证下,在这里做个存档。

 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实现的更多相关文章

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

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

  2. 几大排序算法的Java实现

    很多的面试题都问到了排序算法,中间的算法和思想比较重要,这边我选择了5种常用排序算法并用Java进行了实现.自己写一个模板已防以后面试用到.大家可以看过算法之后,自己去实现一下. 1.冒泡排序:大数向 ...

  3. 7种基本排序算法的Java实现

    7种基本排序算法的Java实现 转自我的Github 以下为7种基本排序算法的Java实现,以及复杂度和稳定性的相关信息. 以下为代码片段,完整的代码见Sort.java 插入排序 /** * 直接插 ...

  4. 几种简单的排序算法(JAVA)

    几种排序算法(JAVA) 一.代码 package com.hdwang; import java.util.Arrays; /** * Created by admin on 2017/1/20. ...

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

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

  6. 几大排序算法的Java实现(原创)

    几大排序算法的Java实现 更新中... 注: 该类中附有随机生成[min, max)范围不重复整数的方法,如果各位看官对此方法有什么更好的建议,欢迎提出交流. 各个算法的思路都写在该类的注释中了,同 ...

  7. 十大经典排序算法(java实现、配图解,附源码)

    前言: 本文章主要是讲解我个人在学习Java开发环境的排序算法时做的一些准备,以及个人的心得体会,汇集成本篇文章,作为自己对排序算法理解的总结与笔记. 内容主要是关于十大经典排序算法的简介.原理.动静 ...

  8. 基本排序算法——冒泡排序java实现

    冒泡排序是原理最简单的一种排序算法,具体思想就不多说了,代码如下: eclipse4.3中编译通过 package sort.basic; import java.util.Arrays; publi ...

  9. 排序算法练习--JAVA(插入、直接选择、冒泡、快速排序、非递归快速排序)

    排序算法是数据结构中的经典算法知识点,也是笔试面试中经常考察的问题,平常学的不扎实笔试时候容易出洋相,回来恶补,尤其是碰到递归很可能被问到怎么用非递归实现... package sort; impor ...

  10. 排序算法(JAVA)

    import java.util.Random;      /**  * 排序测试类  *   * 排序算法的分类如下:  * 1.插入排序(直接插入排序.折半插入排序.希尔排序):  * 2.交换排 ...

随机推荐

  1. office web apps 部署-搭建office web apps服务器

    二.搭建office web apps服务器 相关文件可以去焰尾迭分享的百度网盘下载,下载地址:http://pan.baidu.com/s/1o6tCo8y#path=%252Foffice%252 ...

  2. 学习《ASP.NET MVC5高级编程》——基架

    基架--代码生成的模板.我姑且这么去定义它,在我学习微软向编程之前从未听说过,比如php代码,大部分情况下是我用vim去手写而成,重复使用的代码需要复制粘贴,即使后来我在使用eclipse这样的IDE ...

  3. 忘记了root密码,如何进入系统?

    Issue 问题 忘记了root密码不能进入系统 如何进入系统? 环境 红帽企业版Linux所有版本 解决方法 可以进入单用户模式或者援救模式来改变root密码,如何进入单用户模式取决引导加载程序. ...

  4. session知识总结

    0.什么是会话? - 简单理解:打开浏览器到关闭浏览器过程中的操作.请求. 1.Session是什么? - session是HttpSession的简称: - 用于保存会话状态: - 将会话状态保存在 ...

  5. 2017TSC世界大脑与科技峰会,多角度深入探讨关于大脑意识

    TSC·世界大脑与科技峰会是全世界范围内的集会,多角度深入探讨关于大脑意识体验来源这一根本话题,我们是谁,现实的本质是什么,我们所处宇宙空间的本质为何.该峰会由亚利桑那大学意识研究中心主办. 会议时间 ...

  6. Activity设置全屏显示的两种方式及系统自带theme属性解析

    转载说明:原贴地址:http://blog.csdn.net/a_running_wolf/article/details/50480386 设置Activity隐藏标题栏.设置Activity全屏显 ...

  7. Centos6.5静默安装Oracle11g

    sed -i "s/SELINUX=enforcing/SELINUX=disabled/" /etc/selinux/configsetenforce 0yum -y insta ...

  8. [刷题]算法竞赛入门经典(第2版) 5-10/UVa1597 - Searching the Web

    题意:不难理解,照搬题意的解法. 代码:(Accepted,0.190s) //UVa1597 - Searching the Web //#define _XIENAOBAN_ #include&l ...

  9. bitnami gitlab 安装

    安装gitlab需要安装的依赖软件比较多,基于偷懒的原则,从网上找到了bitnami-gitlab-8.7.1-0-linux-x64-installer.run ,集成了所有的相关软件,一键安装,省 ...

  10. 基于html5 Canvas图表库 : ECharts

    ECharts开源来自百度商业前端数据可视化团队,基于html5 Canvas,是一个纯Javascript图表库,提供直观,生动,可交互,可个性化定制的数据可视化图表.创新的拖拽重计算.数据视图.值 ...