java 复习003 之排序篇
由java 复习003跳转过来的
C语言实现版见some-sort-algorithms
快速排序(不稳定 O(n log n))
package vell.bibi.sort_algorithms; import vell.bibi.sort_algorithms.util.vell001; public class QuickSort { public static int partition(int[] a, int low, int high){
int cup;
cup = a[low]; // 保存关键字
while(high > low){
while(high > low && a[high] >= cup) high--; // 由high开始找,找到小于关键字的位置
a[low] = a[high];
while(high > low && a[low] <= cup) low ++; // 由low开始找,找到大于关键字的位置
a[high] = a[low];
}
a[low] = cup;
return low;
}
public static void sort(int[] a, int low, int high){
if(high <= low) return;
int mid = partition(a, low, high); // 分成两个区
sort(a, low, mid-1);
sort(a, mid+1, high);
}
public static void main(String[] args) {
int[] a = vell001.getRandomList(10, 100);
vell001.printList(a);
sort(a, 0, a.length-1);
vell001.printList(a);
}
}冒泡排序 (稳定 O(n2))
package vell.bibi.sort_algorithms; import vell.bibi.sort_algorithms.util.vell001; public class BubbleSort { public static void sort(int[] a){
int i, j, cup;
boolean flag;
for(i=a.length, flag=true; flag && i>0; i--){
flag = false;
for(j=0; j<i-1; j++){
if(a[j] > a[j+1]){
cup = a[j];
a[j] = a[j+1];
a[j+1] = cup;
flag = true;
}
}
}
}
public static void main(String[] args) {
int[] a = vell001.getRandomList(10, 100);
vell001.printList(a);
sort(a);
vell001.printList(a);
} }希尔排序(不稳定 O(n log n))
package vell.bibi.sort_algorithms; import vell.bibi.sort_algorithms.util.vell001; public class ShellSort {
public static void sort(int[] a){
int i, j, d, cup;
for(d=a.length/2; d>0; d=d/2){
for(i=d; i<a.length; i++){
cup = a[i];
for(j=i-d; j>=0 && a[j]>cup; j=j-d){
a[j+d] = a[j];
}
a[j+d] = cup;
}
}
}
public static void main(String[] args) {
int[] a = vell001.getRandomList(10, 100);
vell001.printList(a);
sort(a);
vell001.printList(a);
} }堆排序(不稳定 O(n log n))
package vell.bibi.sort_algorithms; import vell.bibi.sort_algorithms.util.vell001; public class HeapSort { public static void heapAdjust(int[] a, int father, int length){
int child, cup;
for(child=father*2+1, cup=a[father]; child<length; father=child, child=father*2+1){
if(child+1 < length && a[child+1] > a[child])
child ++;
if(a[child] > cup){
a[father] = a[child];
a[child] = cup;
} else
break;
}
}
public static void sort(int[] a){
int cup;
for(int i=a.length/2; i>=0; i--){
heapAdjust(a, i, a.length);
}
for(int i=a.length-1; i>0; i--){
cup = a[0];
a[0] = a[i];
a[i] = cup;
heapAdjust(a, 0, i);
}
}
public static void main(String[] args) {
int[] a = vell001.getRandomList(10, 100);
vell001.printList(a);
sort(a);
vell001.printList(a);
} }归并排序(稳定 O(n log n) 需要O(n)额外空间)
package vell.bibi.sort_algorithms; import vell.bibi.sort_algorithms.util.vell001; public class MergeSort {
public static void merge(int[] a, int low, int mid, int high){
int i=low, j=mid, k=0;
int[] cup = new int[high-low];
while(i<mid && j<high){
if(a[i] <= a[j])
cup[k++] = a[i++];
else
cup[k++] = a[j++];
}
while(i<mid) cup[k++] = a[i++];
while(j<high) cup[k++] = a[j++];
for(k=0; k<cup.length; k++){
a[low + k] = cup[k];
}
}
public static void sort(int[] a, int low, int high){
if(high - low <= 1) return;
int mid = (high + low) / 2;
sort(a, low, mid);
sort(a, mid, high);
merge(a, low, mid, high);
} public static void main(String[] args) {
int[] a = vell001.getRandomList(10, 100);
vell001.printList(a);
sort(a, 0, a.length);
vell001.printList(a);
} }vell001.java (我的小工具库)
package vell.bibi.sort_algorithms.util; public class vell001 {
public static void printList(int[] a){
for(int i=0; i<a.length; i++){
System.out.print(a[i] + " ");
}
System.out.println();
}
public static int[] getRandomList(int n, int max){
int[] a = new int[n];
for(int i=0; i<n; i++){
a[i] = (int)(Math.random() * max);
}
return a;
}
}
原文地址: http://vview.ml/2014/04/13/some-sort-algorithms-java.html
written by Vell Bibi posted at VBlog
java 复习003 之排序篇的更多相关文章
- java 复习003
今天主要复习下数据结构的东西 树 自平衡二叉查找树 AVL树(高平衡树)(wiki) 特性:任何节点的两个子树的高度最大差别为一 时间复杂度:查找.插入和删除在平均和最坏情况下都是O(log n) 红 ...
- Java基础复习笔记基本排序算法
Java基础复习笔记基本排序算法 1. 排序 排序是一个历来都是很多算法家热衷的领域,到现在还有很多数学家兼计算机专家还在研究.而排序是计算机程序开发中常用的一种操作.为何需要排序呢.我们在所有的系统 ...
- 深入理解Java 8 Lambda(语言篇——lambda,方法引用,目标类型和默认方法)
作者:Lucida 微博:@peng_gong 豆瓣:@figure9 原文链接:http://zh.lucida.me/blog/java-8-lambdas-insideout-language- ...
- [转]深入理解Java 8 Lambda(类库篇——Streams API,Collectors和并行)
以下内容转自: 作者:Lucida 微博:@peng_gong 豆瓣:@figure9 原文链接:http://zh.lucida.me/blog/java-8-lambdas-insideout-l ...
- 【Java面试】基础知识篇
[Java面试]基础知识篇 Java基础知识总结,主要包括数据类型,string类,集合,线程,时间,正则,流,jdk5--8各个版本的新特性,等等.不足的地方,欢迎大家补充.源码分享见个人公告.Ja ...
- Java有用经验总结--Swing篇
Java有用经验总结--Swing篇 前言 本文前言部分为我的一些感想,假设你仅仅对本文介绍的Java有用技巧感兴趣,能够跳过前言直接看正文的内容. 本文的写作动机来源于近期接给人家帮忙写的一个小程序 ...
- Java面试题之基础篇概览
Java面试题之基础篇概览 1.一个“.java”源文件中是否可以包含多个类(不是内部类)?有什么限制? 可以有多个类,但只能有一个public的类,且public的类名必须与文件名相一致. 2.Ja ...
- Java面试知识点之线程篇(二)
前言:接上篇,这里继续对java线程相关知识点进行总结. 1.notify和notifyall的区别 notify()方法能够唤醒一个正在等待该对象的monitor的线程,当有多个线程都在等待该对象的 ...
- Java面试知识点之线程篇(一)
前言:在Java面试中,一定会遇到线程相关问题,因此笔者在这里总结Java中有关线程方面知识点,多数从网上得来(文中会贴出主要参考链接),有些也是笔者在面试中所遇到的问题,如有错误,请不吝指正.主要参 ...
随机推荐
- java.util.zip.ZipOutputStream压缩无乱码(原创)
package io; import java.io.BufferedOutputStream; import java.io.BufferedReader; import java.io.FileI ...
- 创建支持复杂脚本Complex Scripts的WINCE6.0系统
如果要创建支持复杂脚本(Complex Scripts)的系统,我们需要完成下面一系列步骤来确保系统包含所有需要支持的具体区域设置 (locale–specific). 1. 选择intern ...
- [HIHO1051]补提交卡(枚举,贪心)
题目链接:http://hihocoder.com/problemset/problem/1051 思路:先排序,然后枚举连续的长度为m的子段,用这个段之后的第一个天数减去这个段之前的第一个天数再-1 ...
- 让Eclipse和NetBeans共享同一个项目
有的时候,我们会下载一些源代码来学习研究,但是下载下来的工程文件是eclipse的或者是NetBeans的.如果手头上没有eclipse或者没有 NetBeans,或只有其中一个怎么办?又或者,你习惯 ...
- Ogre内存池的使用和说明
大家可能会遇到一些Ogre中的内存分配的方面问题,我对这个总结了一下内存分配的方面资料. Ogre在1.7版本后,统一了内存分配策略,提供了内存是否泄漏的跟踪和内存池等比较方便开发的一些策略,目前提供 ...
- zoj 3778 Talented Chef(思维题)
题目 题意:一个人可以在一分钟同时进行m道菜的一个步骤,共有n道菜,每道菜各有xi个步骤,求做完的最短时间. 思路:一道很水的思维题, 根本不需要去 考虑模拟过程 以及先做那道菜(比赛的时候就是这么考 ...
- Asp.Net微信登录-电脑版扫描二维码登录
像京东,一号店等网站都实现了用微信来登录的功能,就是用手机上的微信扫一扫网站上的二维码,微信上确认后,即可自动用微信的帐号登录网站. 一.创建网站应用 在微信开放平台创建一个网站应用 https:// ...
- 创建TabHost的两种方式的简单分析
最近做了一个TabHost的界面,在做的过程中发现了一些问题,故和大家分享一下. 首先我的界面如下: 目前就我所知,创建TabHost有两种方式,第一种是继承TabActivity类,然后用getTa ...
- java分层架构概念
转自:http://www.cnblogs.com/bdqnbenet/p/4924778.html service是业务层 DAO (Data Access Object) 数据访问 1.JAVA中 ...
- 脚本AI与脚本引擎
Scripted AI and Scripting Engines 脚本AI与脚本引擎 This chapter discusses some of the techniques you can us ...