`
simohayha
  • 浏览: 1386924 次
  • 性别: Icon_minigender_1
  • 来自: 火星
社区版块
存档分类
最新评论

各种排序算法的java实现

    博客分类:
  • java
阅读更多
很早以前学算法的时候写的 ^_^。
1. BubbleSort
import java.util.*;
public class BubbleSort{
public void sort(int[] a){
for(int i=0;i
for(int j=a.length-1;j>=i+1;j--){
if(a[j]
int tmp =a[j];
a[j]=a[j-1];
a[j-1]=tmp;
}
}
}
}
public static void main(String[] args){
int[] a = {1,6,3,8,1,56,};
BubbleSort bs = new BubbleSort();
bs.sort(a);
System.out.println(Arrays.toString(a));
}
}


2 InsertSort

import java.util.*;
public class InsertSort{
private int i=0;
public void sort(int[] a){
for(int j=1;j
int keys = a[j];
i =j-1;
while(i>=0&&a[i]>keys){
a[i+1]=a[i];
i--;
}
a[i+1]=keys;
}
}
public static void main(String[] args){
InsertSort i = new InsertSort();
int[] f={5,2,4,6,1,3,0};
i.sort(f);
System.out.println(Arrays.toString(f));
}
}

3 MergeSort

import java.util.*;
public class MergeSortTest{
private int[] l,r1;
public void merge(int[] a,int p,int q,int r){
int n1 =q-p+1;
int n2 = r-q;
l=new int[n1];
r1 = new int[n2+1];
for(int i=0;i
l[i]=a[p+i];
}
l[n1-1]=Integer.MAX_VALUE;
for(int i=0;i
r1[i]=a[q+i];
}
r1[n2] =Integer.MAX_VALUE;
int i=0;
int j=0;
for(int k=p;k
if(l[i]<=r1[j]){
a[k]=l[i];
i=i+1;
}else{
a[k]=r1[j];
j=j+1;
}
}
}
public void mergeSort(int[] a,int p,int r){
if(p+1
int q=(p+r)/2;
mergeSort(a,p,q);
mergeSort(a,q,r); 
merge(a,p,q,r);
} 
}
public static void main(String[] args){
int[] a1 = {3,41,52,26,38,57,9,49};
MergeSortTest mst =new MergeSortTest();
mst.mergeSort(a1,0,a1.length);
System.out.println(Arrays.toString(a1));
}
}

4 SelectionSort

import java.util.*;
public class MergeSortTest{
private int[] l,r1;
public void merge(int[] a,int p,int q,int r){
int n1 =q-p+1;
int n2 = r-q;
l=new int[n1];
r1 = new int[n2+1];
for(int i=0;i
l[i]=a[p+i];
}
l[n1-1]=Integer.MAX_VALUE;
for(int i=0;i
r1[i]=a[q+i];
}
r1[n2] =Integer.MAX_VALUE;
int i=0;
int j=0;
for(int k=p;k
if(l[i]<=r1[j]){
a[k]=l[i];
i=i+1;
}else{
a[k]=r1[j];
j=j+1;
}
}
}
public void mergeSort(int[] a,int p,int r){
if(p+1
int q=(p+r)/2;
mergeSort(a,p,q);
mergeSort(a,q,r); 
merge(a,p,q,r);
} 
}
public static void main(String[] args){
int[] a1 = {3,41,52,26,38,57,9,49};
MergeSortTest mst =new MergeSortTest();
mst.mergeSort(a1,0,a1.length);
System.out.println(Arrays.toString(a1));
}
}

5 HeapSort

import java.util.*;
public class HeapSort{
private int largest;
public int left(int i){
return 2*i+1;
}
public int right(int j){
return 2*j+2;
}
public void maxHeapify(int[] a,int i){
int l=left(i);
int r=right(i);
if((la[i])){
largest=l;
}else{
largest=i;
}
if((ra[largest])){
largest=r;
}
if(largest!=i){
int temp = a[i];
a[i]=a[largest];
a[largest]=temp;
maxHeapify(a,largest);
}
}
public void buildMaxHeap(int[] a){
for(int i=a.length/2;i>=0;--i){
maxHeapify(a,i);
}
}
public void sort(int[] a){
buildMaxHeap(a);
//System.out.println(Arrays.toString(a));
for(int i=a.length-1;i>=1;--i){
int temp=a[0];
a[0]=a[i];
a[i]=temp;
int[] b= new int[i];
System.arraycopy(a,0,b,0,i-1);
maxHeapify(b,0);
System.arraycopy(b,0,a,0,i-1);
}
}
public static void main(String[] args){
HeapSort hs = new HeapSort();
int[] a={23,17,14,6,13,10,1,5,7};
hs.sort(a);
System.out.println(Arrays.toString(a));
}
}

6 BucketSort

import java.util.*;
public class BucketSort {

/**
* @param args
*/
private LinkedList[] b;
public void sort(double[] a){
int n=a.length;
b=new LinkedList[a.length];
for(int i=0;i
b[(int)(n*a[i])] = new LinkedList();
}
for(int i=0;i
b[(int)(n*a[i])].add(Double.valueOf(a[i])); 
//System.out.println(b[(int)(n*a[i])]);
}
//System.out.println(Arrays.toString(b));
for(int i=0;i
if(b[i]==null){
continue;
}else{
Collections.sort(b[i]);
}
}
}
public static void main(String[] args) {
// TODO Auto-generated method stub
double[] a ={0.79,0.13,0.16,0.64,0.39,0.20,0.89,0.53,0.71,0.42};
BucketSort bs = new BucketSort();
bs.sort(a);
for(int i=0;i
if(bs.b[i]==null){
continue;
}else{
Iterator it =bs.b[i].iterator();
while(it.hasNext()){
System.out.print(it.next()+" ");
}
}
}
//System.out.println(Arrays.toString(bs.b));
}
}

7 CountingSort

import java.util.*;
public class CountingSort {
/**
* @param args
*/
public void Sort(int[] a,int[] b,int k){
int[] c= new int[k+1];
for(int j=0;j
c[a[j]]=c[a[j]]+1;
}
for(int i=1;i
c[i]=c[i]+c[i-1];
}
for(int j=a.length-1;j>=0;j--){
b[c[a[j]]-1]=a[j];
c[a[j]]=c[a[j]]-1;
}
}
public static void main(String[] args) {
// TODO Auto-generated method stub
int[] a=new int[]{3,1,12,11,4,13};
CountingSort cs = new CountingSort();
int[] b = new int[a.length];
cs.Sort(a,b,13);
System.out.println(Arrays.toString(b));
}
}
分享到:
评论

相关推荐

    各种排序算法java实现

    各种排序算法java实现各种排序算法java实现各种排序算法java实现各种排序算法java实现各种排序算法java实现

    _各种排序算法java实现.doc

    _各种排序算法java实现.doc

    各种排序算法 java实现

    总结了几种典型的nlogn的排序算法,实现过程在代码中详细给出了,请大家自己下载就能直接运行,给各位参考吧。

    IT面试笔试-各种排序算法Java实现

    IT常见的面试题目,各种排序算法的Java代码实现,内部有代码和详细的注释信息。

    node-v11.6.0-sunos-x64.tar.xz

    Node.js,简称Node,是一个开源且跨平台的JavaScript运行时环境,它允许在浏览器外运行JavaScript代码。Node.js于2009年由Ryan Dahl创立,旨在创建高性能的Web服务器和网络应用程序。它基于Google Chrome的V8 JavaScript引擎,可以在Windows、Linux、Unix、Mac OS X等操作系统上运行。 Node.js的特点之一是事件驱动和非阻塞I/O模型,这使得它非常适合处理大量并发连接,从而在构建实时应用程序如在线游戏、聊天应用以及实时通讯服务时表现卓越。此外,Node.js使用了模块化的架构,通过npm(Node package manager,Node包管理器),社区成员可以共享和复用代码,极大地促进了Node.js生态系统的发展和扩张。 Node.js不仅用于服务器端开发。随着技术的发展,它也被用于构建工具链、开发桌面应用程序、物联网设备等。Node.js能够处理文件系统、操作数据库、处理网络请求等,因此,开发者可以用JavaScript编写全栈应用程序,这一点大大提高了开发效率和便捷性。 在实践中,许多大型企业和组织已经采用Node.js作为其Web应用程序的开发平台,如Netflix、PayPal和Walmart等。它们利用Node.js提高了应用性能,简化了开发流程,并且能更快地响应市场需求。

    node-v12.12.0-linux-s390x.tar.xz

    Node.js,简称Node,是一个开源且跨平台的JavaScript运行时环境,它允许在浏览器外运行JavaScript代码。Node.js于2009年由Ryan Dahl创立,旨在创建高性能的Web服务器和网络应用程序。它基于Google Chrome的V8 JavaScript引擎,可以在Windows、Linux、Unix、Mac OS X等操作系统上运行。 Node.js的特点之一是事件驱动和非阻塞I/O模型,这使得它非常适合处理大量并发连接,从而在构建实时应用程序如在线游戏、聊天应用以及实时通讯服务时表现卓越。此外,Node.js使用了模块化的架构,通过npm(Node package manager,Node包管理器),社区成员可以共享和复用代码,极大地促进了Node.js生态系统的发展和扩张。 Node.js不仅用于服务器端开发。随着技术的发展,它也被用于构建工具链、开发桌面应用程序、物联网设备等。Node.js能够处理文件系统、操作数据库、处理网络请求等,因此,开发者可以用JavaScript编写全栈应用程序,这一点大大提高了开发效率和便捷性。 在实践中,许多大型企业和组织已经采用Node.js作为其Web应用程序的开发平台,如Netflix、PayPal和Walmart等。它们利用Node.js提高了应用性能,简化了开发流程,并且能更快地响应市场需求。

    基于统计分析的葡萄酒评价指标建立以及方案设计.doc

    本文档是课题研究的研究报告内含调研以及源码设计以及结果分析

    node-v12.9.1-linux-ppc64le.tar.xz

    Node.js,简称Node,是一个开源且跨平台的JavaScript运行时环境,它允许在浏览器外运行JavaScript代码。Node.js于2009年由Ryan Dahl创立,旨在创建高性能的Web服务器和网络应用程序。它基于Google Chrome的V8 JavaScript引擎,可以在Windows、Linux、Unix、Mac OS X等操作系统上运行。 Node.js的特点之一是事件驱动和非阻塞I/O模型,这使得它非常适合处理大量并发连接,从而在构建实时应用程序如在线游戏、聊天应用以及实时通讯服务时表现卓越。此外,Node.js使用了模块化的架构,通过npm(Node package manager,Node包管理器),社区成员可以共享和复用代码,极大地促进了Node.js生态系统的发展和扩张。 Node.js不仅用于服务器端开发。随着技术的发展,它也被用于构建工具链、开发桌面应用程序、物联网设备等。Node.js能够处理文件系统、操作数据库、处理网络请求等,因此,开发者可以用JavaScript编写全栈应用程序,这一点大大提高了开发效率和便捷性。 在实践中,许多大型企业和组织已经采用Node.js作为其Web应用程序的开发平台,如Netflix、PayPal和Walmart等。它们利用Node.js提高了应用性能,简化了开发流程,并且能更快地响应市场需求。

    多线程应用程序设计.pdf

    多线程应用程序设计.pdf

    什么是蚁群算法路径规划matlab以及学习蚁群算法路径规划matlab的意义

    蚁群算法路径规划matlab

    IEC 60695-11-3:2012.pdf

    IEC 60695-11-3:2012.pdf

    仿eplie触屏版html5响应式手机wap网站模板下载.zip

    触屏版自适应手机wap软件网站模板 触屏版自适应手机wap软件网站模板

    node-v12.1.0-linux-ppc64le.tar.xz

    Node.js,简称Node,是一个开源且跨平台的JavaScript运行时环境,它允许在浏览器外运行JavaScript代码。Node.js于2009年由Ryan Dahl创立,旨在创建高性能的Web服务器和网络应用程序。它基于Google Chrome的V8 JavaScript引擎,可以在Windows、Linux、Unix、Mac OS X等操作系统上运行。 Node.js的特点之一是事件驱动和非阻塞I/O模型,这使得它非常适合处理大量并发连接,从而在构建实时应用程序如在线游戏、聊天应用以及实时通讯服务时表现卓越。此外,Node.js使用了模块化的架构,通过npm(Node package manager,Node包管理器),社区成员可以共享和复用代码,极大地促进了Node.js生态系统的发展和扩张。 Node.js不仅用于服务器端开发。随着技术的发展,它也被用于构建工具链、开发桌面应用程序、物联网设备等。Node.js能够处理文件系统、操作数据库、处理网络请求等,因此,开发者可以用JavaScript编写全栈应用程序,这一点大大提高了开发效率和便捷性。 在实践中,许多大型企业和组织已经采用Node.js作为其Web应用程序的开发平台,如Netflix、PayPal和Walmart等。它们利用Node.js提高了应用性能,简化了开发流程,并且能更快地响应市场需求。

    node-v12.16.0-darwin-x64.tar.xz

    Node.js,简称Node,是一个开源且跨平台的JavaScript运行时环境,它允许在浏览器外运行JavaScript代码。Node.js于2009年由Ryan Dahl创立,旨在创建高性能的Web服务器和网络应用程序。它基于Google Chrome的V8 JavaScript引擎,可以在Windows、Linux、Unix、Mac OS X等操作系统上运行。 Node.js的特点之一是事件驱动和非阻塞I/O模型,这使得它非常适合处理大量并发连接,从而在构建实时应用程序如在线游戏、聊天应用以及实时通讯服务时表现卓越。此外,Node.js使用了模块化的架构,通过npm(Node package manager,Node包管理器),社区成员可以共享和复用代码,极大地促进了Node.js生态系统的发展和扩张。 Node.js不仅用于服务器端开发。随着技术的发展,它也被用于构建工具链、开发桌面应用程序、物联网设备等。Node.js能够处理文件系统、操作数据库、处理网络请求等,因此,开发者可以用JavaScript编写全栈应用程序,这一点大大提高了开发效率和便捷性。 在实践中,许多大型企业和组织已经采用Node.js作为其Web应用程序的开发平台,如Netflix、PayPal和Walmart等。它们利用Node.js提高了应用性能,简化了开发流程,并且能更快地响应市场需求。

    买花网微信鲜花网触屏版手机wap购物网站模板下载.zip

    触屏版自适应手机wap软件网站模板 触屏版自适应手机wap软件网站模板

    node-v10.22.1-linux-x64.tar.xz

    Node.js,简称Node,是一个开源且跨平台的JavaScript运行时环境,它允许在浏览器外运行JavaScript代码。Node.js于2009年由Ryan Dahl创立,旨在创建高性能的Web服务器和网络应用程序。它基于Google Chrome的V8 JavaScript引擎,可以在Windows、Linux、Unix、Mac OS X等操作系统上运行。 Node.js的特点之一是事件驱动和非阻塞I/O模型,这使得它非常适合处理大量并发连接,从而在构建实时应用程序如在线游戏、聊天应用以及实时通讯服务时表现卓越。此外,Node.js使用了模块化的架构,通过npm(Node package manager,Node包管理器),社区成员可以共享和复用代码,极大地促进了Node.js生态系统的发展和扩张。 Node.js不仅用于服务器端开发。随着技术的发展,它也被用于构建工具链、开发桌面应用程序、物联网设备等。Node.js能够处理文件系统、操作数据库、处理网络请求等,因此,开发者可以用JavaScript编写全栈应用程序,这一点大大提高了开发效率和便捷性。 在实践中,许多大型企业和组织已经采用Node.js作为其Web应用程序的开发平台,如Netflix、PayPal和Walmart等。它们利用Node.js提高了应用性能,简化了开发流程,并且能更快地响应市场需求。

    python实现的基于蒙特卡洛树搜索的AI黑白棋源码带详细注释.zip

    python实现的基于蒙特卡洛树搜索的AI黑白棋源码带详细注释.zip python实现的基于蒙特卡洛树搜索的AI黑白棋源码带详细注释.zip python实现的基于蒙特卡洛树搜索的AI黑白棋源码带详细注释.zip python实现的基于蒙特卡洛树搜索的AI黑白棋源码带详细注释.zip python实现的基于蒙特卡洛树搜索的AI黑白棋源码带详细注释.zip python实现的基于蒙特卡洛树搜索的AI黑白棋源码带详细注释.zip python实现的基于蒙特卡洛树搜索的AI黑白棋源码带详细注释.zip

    node-v11.8.0-sunos-x64.tar.xz

    Node.js,简称Node,是一个开源且跨平台的JavaScript运行时环境,它允许在浏览器外运行JavaScript代码。Node.js于2009年由Ryan Dahl创立,旨在创建高性能的Web服务器和网络应用程序。它基于Google Chrome的V8 JavaScript引擎,可以在Windows、Linux、Unix、Mac OS X等操作系统上运行。 Node.js的特点之一是事件驱动和非阻塞I/O模型,这使得它非常适合处理大量并发连接,从而在构建实时应用程序如在线游戏、聊天应用以及实时通讯服务时表现卓越。此外,Node.js使用了模块化的架构,通过npm(Node package manager,Node包管理器),社区成员可以共享和复用代码,极大地促进了Node.js生态系统的发展和扩张。 Node.js不仅用于服务器端开发。随着技术的发展,它也被用于构建工具链、开发桌面应用程序、物联网设备等。Node.js能够处理文件系统、操作数据库、处理网络请求等,因此,开发者可以用JavaScript编写全栈应用程序,这一点大大提高了开发效率和便捷性。 在实践中,许多大型企业和组织已经采用Node.js作为其Web应用程序的开发平台,如Netflix、PayPal和Walmart等。它们利用Node.js提高了应用性能,简化了开发流程,并且能更快地响应市场需求。

    孪生神经网络-python源码.zip

    孪生神经网络-python源码.zip

    仿GoMobile触屏版html5响应式手机app网站模板下载-懒人模板.zip

    触屏版自适应手机wap软件网站模板 触屏版自适应手机wap软件网站模板

Global site tag (gtag.js) - Google Analytics