1.java常用排序方法

1) 选择排序
         原理:a. 将数组中的每个元素,与第一个元素比较
            如果这个元素小于第一个元素, 就将这个
            两个元素交换.
            b. 每轮使用a的规则, 可以选择出一个最小元素
            放到第一个位置.
          c. 经过n-1轮比较完成排序
     简单说: 每轮选择最小的放到前面.
     原理说明:
     ary={8,2,3,7,1}
     ary={1|8,3,7,2}
     ary={1,2|8,7,3}
     ary={1,2,3|8,7}
     ary={1,2,3,7|8}
     代码分析:
     i 代表第一个数据的位置
     j 代码后部每一个数据的位置
           ary      i j  ary[i] ary[j]  ary[i]>ary[j]  [i]<->[j]
  {8|2,3,7,1}   0 1   8      2        true             8<->2
  {2|8,3,7,1}   0 2   2      3        false
  {2|8,3,7,1}   0 3   2      7        false
  {2|8,3,7,1}   0 4   2      1        true             2<->1
  {1,8|3,7,2}   1 2   8      3        true             8<->3
  {1,3|8,7,2}   1 3   3      7        false        
  {1,3|8,7,2}   1 4   3      2        true             3<->2
  {1,2,8|7,3}   2 3   8      7        true             8<->7
  {1,2,7|8,3}   2 4   7      3        true             7<->3
  {1,2,3,8|7}   3 4   8      7        true             8<->7
  {1,2,3,7,8}   4

  部分重要代码:
    i= 0 ~ < ary.length - 1;
    j=i+1 ~ <ary.length
    if(ary[i]>ary[j]){
        //ary[i]<->ary[j]
        int temp = ary[i];
        ary[i]=ary[j];
        ary[j]=temp;
    }
      
 2) 冒泡排序
    原理: a. 逐一比较数组中相邻的两个元素, 如果后面
            的数字小于前面的数字, 就交换先后元素.
            b. 经过一个轮次的比较, 一定有一个最大的排
            在最后的位置.
            c. 每次比较剩下的元素, 经过n-1次比较, 可以
            实现排序
    简单说: 比较相邻元素,大的向后交换
      原理说明:
     ary={8,2,3,7,1}
     ary={2,8,3,7,1}
     ary={2,3,8,7,1}
     ary={2,3,7,8,1}
     ary={2,3,7,1|8}
     ary={2,3,7,1|8}
     ary={2,3,7,1|8}
     ary={2,3,1|7,8}
     ary={2,3,1|7,8}
     ary={2,1|3,7,8}
     ary={1,2,3,7,8}
     i代表次数
     j代表比较位置
           ary     i  j j+1  ary[j]  ary[j+1] [j]>[j+1]   [j]<->[j+1]
  {8,2,3,7,1}  0 0  1     8          2          true        8<->2
  {2,8,3,7,1}  0 1  2     8          3          true        8<->3
  {2,3,8,7,1}  0 2  3     8          7          true        8<->7
  {2,3,7,8,1}  0 3  4     8          1          true        8<->1
  {2,3,7,1|8}  1 0  1     2          3          false     
  {2,3,7,1|8}  1 1  2     3          7          false
  {2,3,7,1|8}  1 2  3     7          1          true        7<->1
  {2,3,1|7,8}  2 0  1     2          3          false
  {2,3,1|7,8}  2 1  2     3          1          true        3<->1
  {2,1|3,7,8}  3 0  1     2          1          true        2<->1
  {1,2,3,7,8}

  部分重要代码:
    i = 0~ < ary.length-1
    j = 0~ < ary.length - i -1;  
    if([j]>[j+1]){
        [j]<->[j+1]
    }

3) 插入排序
    原理: a. 将数组分为两部分, 将后部分的第一张逐一
            与前部分每一张比较, 如果当前元素小, 就
            一点被比较元素.
            b. 找到合理位置插入.
    原理说明:
     temp = 1
    {8|2,3,7,1}
    {2,8|8,7,1}
    {2,3,8|7,1}
    {2,3,8|8,1}
    {2,3,7,8|8}
    {2,3,7,7|8}
    {2,3,3,7|8}
    {2,2,3,7|8}
    {1,2,3,7|8}
   
     temp 代表取出的待插入元素
     i 代表后组待插入元素 位置
     j 代表前组每个元素的位置
                                            (移动)        插入
          ary      i   t   j   ary[j]    t<[j]      [j]->[j+1]    t->[j+1]
  {8|2,3,7,5}  1  2  0    8        true       8->[j+1]   
  {8|8,3,7,5}  1  2 -1                                           2->[j+1]
  {2,8|3,7,5}  2  3  1    8        true       8->[j+1]
  {2,8|8,7,5}  2  3  0    2        false                      3->[j+1]
  {2,3,8|7,5}  3  7  2    8        true       8->[j+1]
  {2,3,8|8,5}  3  7  1    3        false                      7->[j+1]
  {2,3,7,8|5}  4  5  3    8        true       8->[j+1]
  {2,3,7,8|8}  4  5  2    7        true       7->[j+1]
  {2,3,7,7|8}  4  5  1    3        false                      5->[j+1]
  {2,3,5,7|8}  5

  部分重要代码:
    i= 1 ~ <ary.length, i++
      t = [i];
        j= i-1 ~ >=0, j--
        if(t<[j]){
            [j]->[j+1] //移动
        }else{
             break j;
        }
      t->[j+1]//插入

2. java 系统排序 Arrays.sort(), 排序算法性能很好

3. 方法的递归调用
 1) java 的栈: 是Java进程启动时候在内存中开辟的存储空间
   栈内存的利用方式LIFO(后进先出). Java所有局部变量都在栈中
   分配(压入), 方法的参数也是局部变量, 局部变量在离开作用域
   时候回收 就是从栈中弹出(删除).
 2) Java方法调用使用栈实现, 递归调用就是栈实现的
 3) 递归时候要按照递归深度分配全部临时变量, 栈开销很大, 性能
   不好, 要注意不要超过栈的大小, 并且一定要给出结束条件, 否则
   会造成栈溢出错误.
   
  案例:1+2+3+...+n=f(n)=n+f(n-1) && (n>0, f(1)=1)  
 注意事项: 解决问题简练,性能很差。一定给出结束条件。

                                                                    若有不完善的地方请大家多提意见,转发时请注明出处!

java常见排序方法的更多相关文章

  1. 转:Java实现几种常见排序方法

    日常操作中常见的排序方法有:冒泡排序.快速排序.选择排序.插入排序.希尔排序,甚至还有基数排序.鸡尾酒排序.桶排序.鸽巢排序.归并排序等. 冒泡排序是一种简单的排序算法.它重复地走访过要排序的数列,一 ...

  2. Java实现几种常见排序方法

    日常操作中常见的排序方法有:冒泡排序.快速排序.选择排序.插入排序.希尔排序,甚至还有基数排序.鸡尾酒排序.桶排序.鸽巢排序.归并排序等. 以下常见算法的定义 1. 插入排序:插入排序基本操作就是将一 ...

  3. Java常见排序算法之直接插入排序

    在学习算法的过程中,我们难免会接触很多和排序相关的算法.总而言之,对于任何编程人员来说,基本的排序算法是必须要掌握的. 从今天开始,我们将要进行基本的排序算法的讲解.Are you ready?Let ...

  4. Java常见排序算法之堆排序

    在学习算法的过程中,我们难免会接触很多和排序相关的算法.总而言之,对于任何编程人员来说,基本的排序算法是必须要掌握的. 从今天开始,我们将要进行基本的排序算法的讲解.Are you ready?Let ...

  5. Java常见排序算法之直接选择排序

    在学习算法的过程中,我们难免会接触很多和排序相关的算法.总而言之,对于任何编程人员来说,基本的排序算法是必须要掌握的. 从今天开始,我们将要进行基本的排序算法的讲解.Are you ready?Let ...

  6. Java常见排序和编程算法

    快速排序算法 快速排序是由东尼·霍尔所发展的一种排序算法.在平均状况下,排序 n 个项目要Ο(n log n)次比较.在最坏状况下则需要Ο(n2)次比 较,但这种状况并不常见.事实上,快速排序通常明显 ...

  7. Java常见排序算法之归并排序

    在学习算法的过程中,我们难免会接触很多和排序相关的算法.总而言之,对于任何编程人员来说,基本的排序算法是必须要掌握的. 从今天开始,我们将要进行基本的排序算法的讲解.Are you ready?Let ...

  8. Java常见排序算法之Shell排序

    在学习算法的过程中,我们难免会接触很多和排序相关的算法.总而言之,对于任何编程人员来说,基本的排序算法是必须要掌握的. 从今天开始,我们将要进行基本的排序算法的讲解.Are you ready?Let ...

  9. Java常见排序算法之折半插入排序

    在学习算法的过程中,我们难免会接触很多和排序相关的算法.总而言之,对于任何编程人员来说,基本的排序算法是必须要掌握的. 从今天开始,我们将要进行基本的排序算法的讲解.Are you ready?Let ...

随机推荐

  1. 关于php的一些安全知识

    绝不要以明文形式显示或发送密码.即使是对密码的所有者也应该这样.如果你需要 "忘记密码" 的功能,可以随机生成一个新的 一次性的(这点很重要)密码,然后把这个密码发送给用户 你希望 ...

  2. 11.巨坑,注意了,关于显示不正常的问题,localstorage的存储问题

    在存储时,localstorage和sessionstorage只能存储字符串,所以,必须把json转换为字符串再存,JSON.stringify

  3. 浏览器json格式化插件 yformater

    本人最近做的工作就是写interface,几个前端写前端,他们需要什么样的数据格式,我就得返回这样的数据格式.这就导致每一个接口都得检查json格式是否是他们所需要的.但浏览器直接请求的json格式很 ...

  4. 【前端】用jQuery实现瀑布流效果

    jQuery实现瀑布流效果 何为瀑布流: 瀑布流,又称瀑布流式布局.是比较流行的一种网站页面布局,视觉表现为参差不齐的多栏布局,随着页面滚动条向下滚动,这种布局还会不断加载数据块并附加至当前尾部.最早 ...

  5. 中文里带半角空格导致的Text换行问题[Unity]

    0x01 问题 最近策划反映了个问题,游戏里的多行文本会出现提前换行的问题,如下图所示: 文本错误地提前换行,导致第一行文本后面有大块空白区域 通过观察可以发现,当字符串中带有半角空格,且半角空格后面 ...

  6. Javasript 正则匹配任意字符

    今天在写Js匹配任意字符的时候发现使用.不好使,当输入内容有回车的时候就会失效. 后来上网查,发现js的任意字符不包括\n. 本来想写一个trim后长度为10的正则验证,最后使用[\s|\S]来代替任 ...

  7. C# 汉语转拼音

    汉语转拼音或首字母 通常不少网站上有汉语转拼音功能,今天就小记下这段汉语转拼音的代码,自己测试ok,现把代码贴出来,以备日后使用: 效果 用法很简单后台使用到了两个类文件,一个是:ConvertHzT ...

  8. 智联招聘 卓聘IM演进过程

    1.  卓聘IM开发背景 智联卓聘是智联旗下高端人才招聘平台,成立快4年了,业务增涨每年以100%速度增涨,业务增涨快在开发和上线速度要求也比较高. 2016年6月提出IM开发需求,7月初上线,开发人 ...

  9. flume 1.7在windows下的安装与测试

    一.安装 安装java,配置环境变量. 安装flume,下载地址,下载后直接解压即可. 二.运行 创建配置文件:在解压后的文件 apache-flume-1.7.0-bin\conf下创建一个exam ...

  10. JAVA的高并发编程

    一.多线程的基本知识 1.1进程与线程的介绍 程序运行时在内存中分配自己独立的运行空间,就是进程 线程:它是位于进程中,负责当前进程中的某个具备独立运行资格的空间. 进程是负责整个程序的运行,而线程是 ...