初学算法,肯定会编写排序算法

其中两个最为有名的就是冒泡排序和快速排序

理论上冒泡排序的时间复杂度为O(N^2),快速排序的时间复杂度为O(NlogN)

下面本门使用JAVA,分别编写三段排序程序

  1. 对十万个0-9999的整数进行一次冒泡排序

  2. 对十万个0-9999的整数进行1000次快速排序,使用递归完成

  3. 对十万个0-9999的整数进行1000次快速排序,使用堆栈完成

对十万个0-9999的整数进行一次冒泡排序:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
package sort;
 
import java.util.Date;
 
public class PopSort {
    public static void main(String[] args){
        int N=100000;
        int[] array=new int[N];
        for(int i=0;i<N;i++)
            array[i]=(int) (Math.random()*9999);
         
        Date begin=new Date();
         
        for(int i=N-1;i>1;i--){
            for(int j=0;j<i;j++){
                if(array[j]>array[j+1]){
                    int tmp=array[j];
                    array[j]=array[j+1];
                    array[j+1]=tmp;
                }
            }
        }
         
        Date end=new Date();
        System.out.println("使用冒泡排序,对 " +N+ "个整数进行排序,用时:" +String.valueOf(end.getTime()-begin.getTime())+ "毫秒");
        for(int i=0;i<100;i++)
            System.out.print(array[i]+" ");
    }
}

执行结果:

下面是使用递归方法的快速排序:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
package sort;
 
import java.util.Date;
 
public class QuickSort {
    public static void main(String[] args){
        int K=1000;
        int N=100000;
        Date begin = new Date();
         
        for(int num=0;num<K;num++){
            int[] array=new int[N];
     
            for(int i=0;i<N;i++)
                array[i]=(int) (Math.random()*9999);
             
             
             
            sort(array,0,array.length-1);
             
        }
        Date end=new Date();
        long time=end.getTime()-begin.getTime();
        System.out.println("使用递归方式进行快速排序,对 " +N+ "个整数进行排序 " +K+ "次,用时:" +String.valueOf(time)+ "毫秒\n平均用时:"+time/K+"毫秒");
    }
     
    private static void sort(int[] array,int begin,int end){
        int right=end,left=begin;
        while(right!=left){
            for(;right>left;right--){
                if(array[begin]>=array[right])
                    break;
            }
            for(;left<right;left++){
                if(array[begin]<array[left])
                    break;
            }
             
            if(left!=right){
                int tmp=array[left];
                array[left]=array[right];
                array[right]=tmp;
            }else if(right!=begin){
                int tmp=array[begin];
                array[begin]=array[left];
                array[left]=tmp;
            }
        }
         
        if(left-1>begin)
            sort(array,begin,left-1);
        if(right+1<end)
            sort(array,right+1,end);
    }
}

执行结果:

最后一段程序是使用数据结构栈来实现的非递归快速排序算法:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
package sort;
 
import java.util.Date;
import java.util.Stack;
 
/**
 * 使用栈而不是递归来实现快排
 * @author newflydd@189.cn
 * Time : 2016年1月8日 下午9:51:49
 */
public class QuickSort2 {
 
    public static void main(String[] args) {
        Date begin = new Date();
        Date end=null;
        int K=1000;
        int N=100000;
         
        for(int num=0;num<K;num++){
            int[] array=new int[N];
            for(int i=0;i<N;i++)
                array[i]=(int) (Math.random()*9999);
            Stack<Node> stack=new Stack<Node>();
            stack.add(new Node(0,N-1));
             
            while(!stack.isEmpty()){
                Node node=stack.pop();
                int right=node.end , left=node.begin;
                while(right!=left){
                    for(;right>left;right--)
                        if(array[node.begin]>=array[right])
                            break;
                    for(;left<right;left++)
                        if(array[node.begin]<array[left])
                            break;
                     
                    if(left!=right){
                        int tmp=array[left];
                        array[left]=array[right];
                        array[right]=tmp;
                    }else if(right!=node.begin){
                        int tmp=array[node.begin];
                        array[node.begin]=array[right];
                        array[right]=tmp;
                    }
                }
                 
                if(left-1>node.begin)
                    stack.push(new Node(node.begin,left-1));
                if(node.end>right+1)
                    stack.push(new Node(right+1,node.end));
            }
             
             
        }
        end=new Date();
        long time=end.getTime()-begin.getTime();
        System.out.println("使用数据结构栈进行快速排序,对 " +N+ "个整数进行排序 " +K+ "次,用时:" +String.valueOf(time)+ "毫秒\n平均用时:"+time/K+"毫秒");
    }
}
 
class Node{
    public int begin;
    public int end;
    public Node(int begin,int end){
        this.begin=begin;
        this.end=end;
    }
}

执行结果:

综上所述,可以直观的看出来

  1. 复杂度为O(N^2)的冒泡排序速度相当慢,一次排序就要18秒,而复杂度为O(NlogN)的快速排序基本上20毫秒内就搞定,这就是算法的力量啊。

  2. 递归函数在这里并不会影响性能,直观,简洁的递归算法是相当实用的,除非动态规划算法一定要将递归转变成循环,否则大多数情况下并不需要改变递归方法,而非递归算法因为会引入其他数据结构,有可能导致程序还会稍稍有些额外开支。

本文来自:http://www.hexcode.cn/article/4090/show

最新文章

  1. (转)Nginx SSL+tomcat集群,request.getScheme() 取到https正确的协议
  2. hdoj 1874 畅通工程续
  3. nyoj 108 士兵杀敌(一)
  4. Boost.Asio c++ 网络编程翻译(20)
  5. Linux释放内存
  6. null类型的字段加1
  7. mknod用法以及主次设备号【转】
  8. 我的Python---1
  9. iOS中多种方式实现打电话、发短信、写邮件
  10. python的bit_length方法
  11. Hbase的基本操作(CDH组件可用)
  12. HttpServletRequestWrapper使用技巧(自定义session和缓存InputStream)
  13. 使用maven-shade-plugin打包spring项目为可执行的jar包
  14. ubuntu声音问题
  15. linux之安装nali本地解析IP归属
  16. List、Set、Map
  17. ssh在本地调用远程主机上的命令,不登录远程主机shell
  18. Android Activity的生命周期的几个方法介绍
  19. 手动编译安装Libvirt之后利用systemctl管理libvirtd服务
  20. Perl中的字符串操作函数

热门文章

  1. 可执行文件(ELF)格式之讲解
  2. console中一些不常用的实用方法
  3. 10 个让人惊讶的 jQuery 插件
  4. 7件你不知道但可以用CSS做的事
  5. javascript设计模式--状态模式(State)
  6. [大牛翻译系列]Hadoop(5)MapReduce 排序:次排序(Secondary sort)
  7. React Native 简介:用 JavaScript 搭建 iOS 应用 (1)
  8. POJ 2549
  9. POJ 3662
  10. (4)用opengl读入off文件生成可执行文件把模型显示出来(未完待续)