内部排序比较(Java版)
内部排序比较(Java版)
2017-06-21
目录
1 三种基本排序算法
1.1 插入排序
1.2 交换排序(冒泡)
1.3 选择排序(简单)
2 比较
3 补充
3.1 快速排序
3.2 什么是桶排序
3.3 堆排序
1 三种基本排序算法
1.1 插入排序
public static void InsertSort(int[] arrs) {
int j;
int tmp;
for (int i = 1; i < arrs.length; i++) {
tmp = arrs[i];
for (j = i - 1; j >= 0 && tmp < arrs[j]; j--) {
arrs[j + 1] = arrs[j];
}
arrs[j + 1] = tmp;
}
}
1.2 交换排序(冒泡)
public static void BubbleSortS(int[] arrs) {
int tmp;
for (int i = arrs.length - 1; i > 0; i--) {
for (int j = 0; j < i; j++) {
if (arrs[j] > arrs[j + 1]) {
tmp = arrs[j];
arrs[j] = arrs[j + 1];
arrs[j + 1] = tmp;
}
}
}
}
1.3 选择排序(简单)
public static void SelectSort(int[] arrs) {
int minIndex;
int tmp;
for (int i = 0; i < arrs.length - 1; i++) {
minIndex = i;
for (int j = i + 1; j < arrs.length; j++) {
if (arrs[minIndex] > arrs[j])
minIndex = j;
}
if (minIndex != i) {
tmp = arrs[minIndex];
arrs[minIndex] = arrs[i];
arrs[i] = tmp;
}
}
}
2 比较
| 排序方法 | 复杂度 | 辅助空间 | 内外循环 | 一次内循环取最大数 | 一次循环交换次数 |
| 插入排序 | O(n2) | 1 | i=1->length-1 j=i-1->0 |
否 | O(1) |
| 冒泡排序 | O(n2) | 1 | i=length-1->1 j=0->i-1 |
是 | O(n) |
| 选择排序 | O(n2) | 2 | i=0->length-1 j=i+1->length-1 |
是 | O(1) |
内部排序(C#)
3 补充
3.1 快速排序
快速排序是对冒泡排序的一种改进。
- 时间复杂度,最坏是O(n2),一般O(nlogn),
- 空间复杂度(递归实现),在一般情况下的空间复杂度为O(logn),在最差的情况下,若每次只完成了一个元素,那么空间复杂度为O(n)
/**
* 快速排序是在冒泡排序的基础上改进而来的,冒泡排序每次只能交换相邻的两个元素,而快速排序是跳跃式的交换,交换的距离很大,因此总的比较和交换次数少了很多,速度也快了不少。
* 时间复杂度,最坏是O(n2),一般O(nlogn)
*/
public class QuickSort
{
public static void main(String[] args)
{
int[] arr=new int[]{1,5,2,3,6,8,4,9,7,5};
QuickSort quickSort=new QuickSort(arr);
quickSort.sort();
quickSort.print();
} private int[] arr;
public QuickSort(int[] arr)
{
this.arr=arr;
} public void sort()
{
quickSort(arr,0,arr.length-1);
} public void quickSort(int[] arr,int begin,int end)
{
if(begin<end)
{
int i = partition(arr, begin, end);
quickSort(arr,begin,i-1);
quickSort(arr,i+1,end);
}
} private int partition(int[] arr, int begin, int end) {
int key=arr[begin];
while(begin<end)
{
while (begin<end&&arr[end]>=key)end--;
if(begin<end) {
arr[begin] = arr[end];
}
while(begin<end&&arr[begin]<=key)begin++;
if(begin<end) {
arr[end] = arr[begin];
}
}
arr[begin]=key;
return begin;
} public void print()
{
for(int value:arr)
System.out.println(value);
}
}
3.2 什么是桶排序
桶排序,也叫作箱排序,是一个排序算法,也是所有排序算法中最快、最简单的排序算法。其中的思想是我们首先需要知道所有待排序元素的范围,然后需要有在这个范围内的同样数量的桶,接着把元素放到对应的桶中,最后按顺序输出。
- 时间复杂度为O(n+m)
- 空间复杂度是O(m),其中m为桶的个数,
/**
* 桶排序,也叫作箱排序,是一个排序算法,也是所有排序算法中最快、最简单的排序算法。
* 其中的思想是我们首先需要知道所有待排序元素的范围,然后需要有在这个范围内的同样数量的桶,接着把元素放到对应的桶中,最后按顺序输出。
* 由于时间复杂度为O(n+m),m为桶容量,如果m比n大太多,则从时间上来说,性能也并不是很好。
*/
public class BucketSort {
public static void main(String[] args)
{
int[] needSortedArr=new int[]{9,2,3,0,3};
BucketSort bucketSort=new BucketSort(10,needSortedArr);
bucketSort.sort();
bucketSort.print();
} private int[] buckets;
private int[] array; public BucketSort(int range,int[] array)
{
this.buckets=new int[range];
this.array=array;
} public void sort()
{
if(array!=null&&array.length!=0)
{
for(int i=0;i<array.length;i++)
{
buckets[array[i]]++;
}
}
} public void print()
{
for(int i=0;i<buckets.length;i++)
{
for(int j=buckets[i];j>0;j--)
System.out.println(i);
}
}
}
3.3 堆排序
堆的定义

我们可以吧这个序列看成一个二叉树,可得, 1)最大堆的根节点最大,2)上层总比下层大
- 时间复杂度是O(logn)
public class HeapSort {
public static void main(String[] args) {
int[] array = { 8, 6, 9, 7, 5, 4, -3, -2, -1, 0, 1, 2, 3 };
System.out.println("Before heap:");
printArray(array);
printHeapTree(array);
System.out.println("build max heap:");
buildMaxHeap(array);
printArray(array);
printHeapTree(array);
heapSort(array);
System.out.println("After heap sort:");
printArray(array);
printHeapTree(array);
}
public static void heapSort(int[] array) {
if (array == null || array.length <= 1) {
return;
}
//建大顶堆
buildMaxHeap(array);
//堆排序
for (int i = array.length - 1; i >= 1; i--) {
exchangeElements(array, 0, i);
maxHeap(array, i, 0);
}
}
private static void buildMaxHeap(int[] array) {
if (array == null || array.length <= 1) {
return;
}
int half = array.length / 2-1;
for (int i = half; i >= 0; i--) {
maxHeap(array, array.length, i);
}
}
//时间复杂度O(logN)
private static void maxHeap(int[] array, int heapSize, int index) {
int left = index * 2 + 1;
int right = index * 2 + 2;
int largest = index;
if (left < heapSize && array[left] > array[index]) {
largest = left;
}
if (right < heapSize && array[right] > array[largest]) {
largest = right;
}
if (index != largest) {
exchangeElements(array, index, largest);
maxHeap(array, heapSize, largest);
}
}
public static void printArray(int[] array) {
System.out.print("{");
for (int i = 0; i < array.length; i++) {
System.out.print(array[i]);
if (i < array.length - 1) {
System.out.print(", ");
}
}
System.out.println("}");
}
private static void printHeapTree(int[] array)
{
for(int i=1;i<array.length;i=i*2)
{
for(int k=i-1;k<2*(i)-1&&k<array.length;k++)
{
System.out.print(array[k]+" ");
}
System.out.println();
}
}
public static void exchangeElements(int[] array, int index1, int index2) {
int temp = array[index1];
array[index1] = array[index2];
array[index2] = temp;
}
}
内部排序比较(Java版)的更多相关文章
- 排序算法Java版,以及各自的复杂度,以及由堆排序产生的top K问题
常用的排序算法包括: 冒泡排序:每次在无序队列里将相邻两个数依次进行比较,将小数调换到前面, 逐次比较,直至将最大的数移到最后.最将剩下的N-1个数继续比较,将次大数移至倒数第二.依此规律,直至比较结 ...
- 常见的链表排序(Java版)
上篇博客中讲解了九大内部排序算法,部分算法还提供了代码实现,但是那些代码实现都是基于数组进行排序的,本篇博客就以链表排序实现几种常见的排序算法,以飨读者. 快速排序的链表实现 算法思想:对于一个链表, ...
- 排序算法系列:选择排序算法JAVA版(靠谱、清晰、真实、可用、不罗嗦版)
在网上搜索算法的博客,发现一个比较悲剧的现象非常普遍: 原理讲不清,混乱 啰嗦 图和文对不上 不可用,甚至代码还出错 我总结一个清晰不罗嗦版: 原理: 从数组头元素索引i开始,寻找后面最小的值(比i位 ...
- 常用排序算法--java版
package com.whw.sortPractice; import java.util.Arrays; public class Sort { /** * 遍历一个数组 * @param sor ...
- 高速排序(Java版)
package com.love.test; import java.util.Scanner; /** * @author huowolf *高速排序实现 *快排是十分优秀的排序算法. *核心:分治 ...
- 打乱式排序的Java版实现
项目中涉及到对大批量的数据进行打乱式排序,大概原理如下: 输入源数据:1,1,2,3,3,3,4,4 输出结果: 1,2,3,4,1,3,4,3 实现代码如下,采用递归的思想: static &l ...
- 排序算法Java版
选择排序: public static void selectSort(int[]a) { int minIndex=0; int temp=0; if((a==null)||(a.length==0 ...
- 排序小结(java版)
一.归并排序 package org.lxh.demo08.b; class Sort { private int[] a; private int n; Sort(int n) { a=new in ...
- 选择排序(java版)
public class SelectSortTest { public static void selectSort(int[] source) { for (int i = 0; i < s ...
- 常见排序算法总结(java版)
一.冒泡排序 1.原理:相邻元素两两比较,大的往后放.第一次完毕,最大值在最大索引处. 即使用相邻的两个元素一次比价,依次将最大的数放到最后. 2.代码: public static void bub ...
随机推荐
- c++ 11 override final
C++ 11添加了两个继承控制关键字:override和final. override确保在派生类中声明的重载函数跟基类的虚函数有相同的签名.final阻止类的进一步派生和虚函数的进一步重载
- MATLAB 的unique函数——数组矩阵的唯一值
MATLAB 的unique函数——求数组矩阵的唯一值 相关MathWork文档见此:unique数组中的唯一值 1.C = unique(A) 返回与 A 中相同的数据,但是不包含重复项.C 已按照 ...
- 上海租房找房建议及条件,上海IT行业开发常见公司的位置地点
上海租房,找房条件 以2号地铁线为中心,优先选择(回家方便,重点!),交通设施较集中地铁:2,3,4 区:普陀区,静安区,长宁区,闸北区,浦东新区,闵行区,徐汇区 路:镇坪路,威宁路,娄山关路,中山公 ...
- linux 文件系统工作原理
转:<http://linuxperf.com/?p=153> 一.概述 文件系统要解决的一个关键问题是怎样防止掉电或系统崩溃造成数据损坏,在此类意外事件中,导致文件系统损坏的根本原因在于 ...
- 【Oracle】Oracle中复合数据类型
1,常见的操作数据库的技术有那些 jdbc 使用java 访问数据库的技术 PLSQL (procedure 过程化sql) 在数据库内部操作数据的技术 proc/c++ ...
- 你真的了解字典(Dictionary)吗? C# Memory Cache 踩坑记录 .net 泛型 结构化CSS设计思维 WinForm POST上传与后台接收 高效实用的.NET开源项目 .net 笔试面试总结(3) .net 笔试面试总结(2) 依赖注入 C# RSA 加密 C#与Java AES 加密解密
你真的了解字典(Dictionary)吗? 从一道亲身经历的面试题说起 半年前,我参加我现在所在公司的面试,面试官给了一道题,说有一个Y形的链表,知道起始节点,找出交叉节点.为了便于描述,我把上面 ...
- python练习笔记——组合恒等式
排列组合结合恒等式 已知从n个物品中取出m个,则存在一个组合恒等式. C(n, m)=C(n, n-m)=C(n-1, m-1)+C(n-1,m) 其中C(n,0) = 1 求:从5取3 和 10 取 ...
- Transparent Huge Pages
在RHEL6中,透明大页功能是默认开启的. 开启该选项后,内核会尽可能地尝试分配大页,如果mmap区域是2mb,那么每个linux进程都会分配到2mb大小的页.如果大页不够用了(比如物理内存不够了), ...
- HighCharts实现多数据折线图分列显示
HighCharts实现多数据折线图分列显示 BY ZYZ HighCharts是一个很好用的web端绘图插件,用起来很方便,它的官方支持很好.并且有中文API(不全然).画出来的图像也挺美丽的. 近 ...
- 命令行运行python项目文件,报错:ModuleNotFoundError: No module named 'xxxx' 解决办法
在pycharm中写好了自动化测试脚本,并能在pycharm中正常运行,由于要考虑到无人值守时能自动执行,执行时就需要脱离pycharm,直接能用命令执行.但是直接用命令执行用例文件:python3 ...