排序算法
2017-02-09 08:37
204 查看
package cn.hanb.study.action;
public class Main {
//冒泡排序 在一次排序后,把最小的元素放在最前面。时间复杂度O(n^2)
public static int[] BubbleSort(int[] arr){
if(arr==null||arr.length==0){
return null ;
}else{
int size=arr.length;
for(int i=0;i<size;i++){
for(int j=size-1;j>i;j++){
if(arr[j]<arr[j-1]){
swap(arr,j-1,j);
}
}
}
return arr;
}
}
//选择排序 只在确定了最小数的前提下才进行交换,大大减少了交换的次数。时间复杂度O(n^2)
public static int[] SelectSort(int[] arr){
if(arr==null||arr.length==0){
return null;
}else{
int size=arr.length;
for(int i=0;i<size;i++){
int min=i;
for(int j=i+1;j<size;j++){
if(arr[min]>arr[j]){
min=j;
}
}
if(arr[i]>arr[min]){
swap(arr,i,min);
}
}
return arr;
}
}
public static void main(String[] args) {
int[] p = new int[]{4,2,6,3,8,1};
BubbleSort(p);
System.out.println(p[0]+" "+p[1]+" "+p[2]+" "+p[3]+" "+p[4]+" "+p[5]);
}
public static void swap(int[] arr,int i,int j){
int n=arr[i];
arr[i]=arr[j];
arr[j]=n;
}
}
public class Main {
//冒泡排序 在一次排序后,把最小的元素放在最前面。时间复杂度O(n^2)
public static int[] BubbleSort(int[] arr){
if(arr==null||arr.length==0){
return null ;
}else{
int size=arr.length;
for(int i=0;i<size;i++){
for(int j=size-1;j>i;j++){
if(arr[j]<arr[j-1]){
swap(arr,j-1,j);
}
}
}
return arr;
}
}
//选择排序 只在确定了最小数的前提下才进行交换,大大减少了交换的次数。时间复杂度O(n^2)
public static int[] SelectSort(int[] arr){
if(arr==null||arr.length==0){
return null;
}else{
int size=arr.length;
for(int i=0;i<size;i++){
int min=i;
for(int j=i+1;j<size;j++){
if(arr[min]>arr[j]){
min=j;
}
}
if(arr[i]>arr[min]){
swap(arr,i,min);
}
}
return arr;
}
}
public static void main(String[] args) {
int[] p = new int[]{4,2,6,3,8,1};
BubbleSort(p);
System.out.println(p[0]+" "+p[1]+" "+p[2]+" "+p[3]+" "+p[4]+" "+p[5]);
}
public static void swap(int[] arr,int i,int j){
int n=arr[i];
arr[i]=arr[j];
arr[j]=n;
}
}
相关文章推荐
- ubuntu桌面上的任务栏和启动器不见了
- 【BZOJ 2079】[Poi2010]Guilds 暴力
- 基于Spark的公安大数据实时运维技术实践
- MAMP下 添加插件问题例如 pcntl & php升级问题
- shell脚本执行方法
- vsftpd服务自启动的三种方法
- OpenWRT-Wifidog之利用Luci认证
- 虚拟机网络配置详解(NAT、桥接、Hostonly) z
- ASP.NET AJAX Advance Tips & Tricks (11) 三种方法动态创建Tooltip
- 数据结构之 二叉树的储存和遍历总结
- 一个不错的redis gui客户端
- php从身份证获取性别和出生年月
- 【4Large-Style】前端框架设计——Button 的设计思路
- ASP.NET AJAX Advance Tips & Tricks (10) 解决使用AJAX Extender时的页面导出(Word/Excel)问题(Extender control 'XXX'
- ASP.NET AJAX Advance Tips & Tricks (9) DropDownList在Firefox下的奇怪现象和解决方案——谁的BUG?
- vue2.0 router遇到的问题
- Working out - b(dp之路)
- java8 HashMap解析
- 从左到右将二进制数转化为十进制数
- CheckStyle规则属性说明