Android 面试专辑Android开发Android技术知识

Android面试-算法学习

2017-11-07  本文已影响178人  白帽子耗子

排序

选择排序

选择排序图解
  1. 将整个序列分为无序区和有序区,初始时候有序区为空,无序区含有待排序的所有记录。
  2. 在无序区中选取最小的元素,将它与无序区的第一个元素交换,使得有序区扩展了一位,同时无序区减少了一位。
  3. 重复 2 ,直到无序区只剩下一个记录为之。此时所有的记录已经从小到大排序完毕。
    public static  void sort(int[] array){
        int len = array.length;
        for (int i = 0; i < len; i++){
            //对n个元素进行n-1次简单排序
            int index = i; 
            for(int j = i + 1; j < len; j++){
                //在这层循环里面找出最小的元素
                if(array[j] < array[index]){
                    index = j;
                }
            }
            if(index != i){
                int tem = array[i];
                array[i] = array[index];
                array[index] = tem;
            }
        }
    }

冒泡排序(稳定)

冒泡排序,又称起泡排序。是交换排序中最简单的排序方法。

  1. 将整个序列分为无序区和有序区,初始时候有序区为空,无序区含有待排序的所有记录。
  2. 对无序区从前到后依次相邻的元素两两比较,反序则交换,从而使较小的元素往前移,较大的元素往后移,,一趟下来无序区中最大的元素就会在无序区的最后了,我们把这个元素移除无序区放到有序区中。(像水中的起泡,体积大的先浮上来)
  3. 重复 2 ,直到无序区只剩下一个记录为之。此时所有的记录已经从小到大排序完毕。

快速排序(不稳定)

快速是对冒泡排序的一种改进。在冒泡排序中,记录的比较和移动是两两相邻的元素,把较大的元素一步一步推到后面,因此总的比较次数和移动次数较多。而快速排序是从两端向中间进行的。较大的元素一下子就能从前面移动到后面,这样比较的次数和移动的次数就减少了。


归并排序 (稳定)

归并排序的中心思想还是分治。“归并”的含义就是将两个或者两个以上的有序序列归并成一个有序序列的过程。二路归并排序,是归并排序中最简单的排序方法。

归并排序.jpg

归并排序有个主要问题:如何将两个相邻的有序序列合并成一个有序序列?

因为两个有序序列,在归并过程中,可能会破坏掉原来的序列。像上图中,[20, 60],[10, 50] 在合并中就会破坏原来的序列了。为此,我们设置i, j, k 三个参数,分别指向两个待归并的序列,以及最终序列的当前位置。也就是 [ i→20 , j→10] ,k指向归并结果存放的位置,一开始是k→20 起始位置。

下面是一次归并的代码

/**
* r[start]→r[mid] , r[mid+1]→r[end]
* 下列start、mid、end 三个参数分别对应有序序列的位置如上
*/
void merge (int[] r, int[] merge, int start, int mid, int end){
      int i = start;
      int j = mid + 1;
      int k = start;
      while(i <= mid && j <= end){
          merge[k++] = r[i] >= r[j] ? r[j++] : r[i++];//将小的元素放入merge里面 
      }
      
      if(i <= mid){//第一个子序列没处理完
          while(i <= mid){
              merge[k++] = r[i++];
          }
      } else {
          while(j <= end){//第二个序列没处理完
              merge[k++] = r[j++];
          }
      }
      
      for (int index = start; index <= end; index++)
          r[index] = merge[index];
}

另外要注意的是,使用递归的方式,是先把原来的数组拆分成一个一个的元素,这时候 start>=end ,然后才会开始进行两两归并排序。

//递归实现
void mergeSort(int[] r, int[] merge, int start, int end){
      if(start >= end) return;
  
      int mid = (start + end)/2;
      mergeSort(r, merge, start, mid);
      mergeSort(r, merge, mid+1, end);
  
      merge(r, merge, start, mid, end);
}


待更新。。。

您的点赞鼓励是我的最大动力


我的Android成长日常
上一篇 下一篇

猜你喜欢

热点阅读