<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    Edzy_Java

      BlogJava :: 首頁 ::  ::  ::  :: 管理 ::
      58 隨筆 :: 12 文章 :: 11 評論 :: 0 Trackbacks
      用Java語言實現的各種排序,包括插入排序、冒泡排序、選擇排序、Shell排序、快速排序、歸并排序、堆排序、SortUtil等。

      插入排序:

      package org.rut.util.algorithm.support;
      import org.rut.util.algorithm.SortUtil;
      public class InsertSort implements SortUtil.Sort
      {
       public void sort(int[] data)
       {
        int temp;
        for(int i=1;i for(int j=i;(j>0)&&(data[j] SortUtil.swap(data,j,j-1);
       }
      }

      冒泡排序:

      package org.rut.util.algorithm.support;
      import org.rut.util.algorithm.SortUtil;
      public class BubbleSort implements SortUtil.Sort
       public void sort(int[] data)
       {
        int temp;
        for(int i=0;i for(int j=data.length-1;j>i;j--)
        {
         if(data[j] SortUtil.swap(data,j,j-1);
        }
       }
      }

      選擇排序:

      package org.rut.util.algorithm.support;
      import org.rut.util.algorithm.SortUtil;
      public class SelectionSort implements SortUtil.Sort
      {
       public void sort(int[] data)
       {
        int temp;
        for (int i = 0; i < data.length; i++)
        {
         int lowIndex = i;
         for (int j = data.length - 1; j >i; j--)
         {
          if (data[j] < data[lowIndex])
          {
           lowIndex = j;
          }
         }
         SortUtil.swap(data,i,lowIndex);
        }
       }
      }

    ??????? Shell排序:

      package org.rut.util.algorithm.support;
      import org.rut.util.algorithm.SortUtil;
      public class ShellSort implements SortUtil.Sort
      {
       public void sort(int[] data)
       {
        for(int i=data.length/2;i>2;i/=2)
        {
         for(int j=0;j insertSort(data,j,i);
        }
       }
       insertSort(data,0,1);
      }

      private void insertSort(int[] data, int start, int inc)
      {
       int temp;
       for(int i=start+inc;i for(int j=i;(j>=inc)&&(data[j] SortUtil.swap(data,j,j-inc);
      }

      快速排序:

      package org.rut.util.algorithm.support;
      import org.rut.util.algorithm.SortUtil;
      public class QuickSort implements SortUtil.Sort
      {
       public void sort(int[] data)
       {
        quickSort(data,0,data.length-1);
       }
       private void quickSort(int[] data,int i,int j)
       {
        int pivotIndex=(i+j)/2;
        //swap
        SortUtil.swap(data,pivotIndex,j);
        int k=partition(data,i-1,j,data[j]);
        SortUtil.swap(data,k,j);
        if((k-i)>1) quickSort(data,i,k-1);
        if((j-k)>1) quickSort(data,k+1,j);
       }
       private int partition(int[] data, int l, int r,int pivot)
       {
        do
        {
         while(data[++l] while((r!=0)&&data[--r]>pivot);
         SortUtil.swap(data,l,r);
        }
        while(l SortUtil.swap(data,l,r);
        return l;
       }
      }

      改進后的快速排序:

      package org.rut.util.algorithm.support;
      import org.rut.util.algorithm.SortUtil;
      public class ImprovedQuickSort implements SortUtil.Sort
      {
       private static int MAX_STACK_SIZE=4096;
       private static int THRESHOLD=10;
       public void sort(int[] data)
       {
        int[] stack=new int[MAX_STACK_SIZE];
        int top=-1;
        int pivot;
        int pivotIndex,l,r;
        stack[++top]=0;
        stack[++top]=data.length-1;
        while(top>0)
        {
         int j=stack[top--];
         int i=stack[top--];
         pivotIndex=(i+j)/2;
         pivot=data[pivotIndex];
         SortUtil.swap(data,pivotIndex,j);
         //partition
         l=i-1;
         r=j;
         do
         {
          while(data[++l] while((r!=0)&&(data[--r]>pivot));
          SortUtil.swap(data,l,r);
         }
         while(l SortUtil.swap(data,l,r);
         SortUtil.swap(data,l,j);
         if((l-i)>THRESHOLD)
         {
          stack[++top]=i;
          stack[++top]=l-1;
         }
         if((j-l)>THRESHOLD)
         {
          stack[++top]=l+1;
          stack[++top]=j;
         }
        }
        //new InsertSort().sort(data);
        insertSort(data);
       }
       private void insertSort(int[] data)
       {
        int temp;
        for(int i=1;i for(int j=i;(j>0)&&(data[j] SortUtil.swap(data,j,j-1);
       }
      }

      歸并排序:

      package org.rut.util.algorithm.support;
      import org.rut.util.algorithm.SortUtil;
      public class MergeSort implements SortUtil.Sort
      {
       public void sort(int[] data)
       {
        int[] temp=new int[data.length];
        mergeSort(data,temp,0,data.length-1);
       }
       private void mergeSort(int[] data,int[] temp,int l,int r)
       {
        int mid=(l+r)/2;
        if(l==r) return ;
        mergeSort(data,temp,l,mid);
        mergeSort(data,temp,mid+1,r);
        for(int i=l;i<=r;i++){
        temp[i]=data[i];
       }
       int i1=l;
       int i2=mid+1;
       for(int cur=l;cur<=r;cur++)
       {
        if(i1==mid+1)
        data[cur]=temp[i2++];
        else if(i2>r)
        data[cur]=temp[i1++];
        else if(temp[i1] data[cur]=temp[i1++];
        else
        data[cur]=temp[i2++];
       }
      }
     
      改進后的歸并排序:

      package org.rut.util.algorithm.support;
      import org.rut.util.algorithm.SortUtil;
      public class ImprovedMergeSort implements SortUtil.Sort
      {
       private static final int THRESHOLD = 10;
       public void sort(int[] data)
       {
        int[] temp=new int[data.length];
        mergeSort(data,temp,0,data.length-1);
       }
       private void mergeSort(int[] data, int[] temp, int l, int r)
       {
        int i, j, k;
        int mid = (l + r) / 2;
        if (l == r)
        return;
        if ((mid - l) >= THRESHOLD)
        mergeSort(data, temp, l, mid);
        else
        insertSort(data, l, mid - l + 1);
        if ((r - mid) >THRESHOLD)
        mergeSort(data, temp, mid + 1, r);
        else
        insertSort(data, mid + 1, r - mid);
        for (i = l; i <= mid; i++)
        {
         temp[i] = data[i];
        }
        for (j = 1; j <= r - mid; j++)
        {
         temp[r - j + 1] = data[j + mid];
        }
        int a = temp[l];
        int b = temp[r];
        for (i = l, j = r, k = l; k <= r; k++)
        {
         if (a < b)
         {
          data[k] = temp[i++];
          a = temp[i];
         }
         else
         {
          data[k] = temp[j--];
          b = temp[j];
         }
        }
       }

       private void insertSort(int[] data, int start, int len)
       {
        for(int i=start+1;i for(int j=i;(j>start) && data[j] SortUtil.swap(data,j,j-1);
       }
      }

      堆排序:

      package org.rut.util.algorithm.support;
      import org.rut.util.algorithm.SortUtil;
      public class HeapSort implements SortUtil.Sort
      {
       public void sort(int[] data)
       {
        MaxHeap h=new MaxHeap();
        h.init(data);
        for(int i=0;i h.remove();
        System.arraycopy(h.queue,1,data,0,data.length);
       }
       private static class MaxHeap
       {
        void init(int[] data)
        {
         this.queue=new int[data.length+1];
         for(int i=0;i queue[++size]=data[i];
         fixUp(size);
        }
       }
       private int size=0;
       private int[] queue;
       public int get()
       {
        return queue[1];
       }
       public void remove()
       {
        SortUtil.swap(queue,1,size--);
        fixDown(1);
       }
       //fixdown
       private void fixDown(int k)
       {
        int j;
        while ((j = k << 1) <= size)
        {
         if (j < size && queue[j] j++;
         if (queue[k]>queue[j]) //不用交換
         break;
         SortUtil.swap(queue,j,k);
         k = j;
        }
       }
       private void fixUp(int k)
       {
        while (k >1)
        {
         int j = k >>1;
         if (queue[j]>queue[k])
         break;
         SortUtil.swap(queue,j,k);
         k = j;
        }
       }
      }

      SortUtil:

      package org.rut.util.algorithm;
      import org.rut.util.algorithm.support.BubbleSort;
      import org.rut.util.algorithm.support.HeapSort;
      import org.rut.util.algorithm.support.ImprovedMergeSort;
      import org.rut.util.algorithm.support.ImprovedQuickSort;
      import org.rut.util.algorithm.support.InsertSort;
      import org.rut.util.algorithm.support.MergeSort;
      import org.rut.util.algorithm.support.QuickSort;
      import org.rut.util.algorithm.support.SelectionSort;
      import org.rut.util.algorithm.support.ShellSort;

      public class SortUtil
      {
       public final static int INSERT = 1;
       public final static int BUBBLE = 2;
       public final static int SELECTION = 3;
       public final static int SHELL = 4;
       public final static int QUICK = 5;
       public final static int IMPROVED_QUICK = 6;
       public final static int MERGE = 7;
       public final static int IMPROVED_MERGE = 8;
       public final static int HEAP = 9;
       public static void sort(int[] data)
       {
        sort(data, IMPROVED_QUICK);
       }
       private static String[] name=
       {
        "insert", "bubble", "selection", "shell", "quick", "improved_quick", "merge", "improved_merge", "heap"
       };
       private static Sort[] impl=new Sort[]
       {
        new InsertSort(),
        new BubbleSort(),
        new SelectionSort(),
        new ShellSort(),
        new QuickSort(),
        new ImprovedQuickSort(),
        new MergeSort(),
        new ImprovedMergeSort(),
        new HeapSort()
       };
       public static String toString(int algorithm)
       {
        return name[algorithm-1];
       }
       public static void sort(int[] data, int algorithm)
       {
        impl[algorithm-1].sort(data);
       }
       public static interface Sort
       {
        public void sort(int[] data);
       }
       public static void swap(int[] data, int i, int j)
       {
        int temp = data[i];
        data[i] = data[j];
        data[j] = temp;
       }
      }
    posted on 2007-03-14 11:16 lbfeng 閱讀(243) 評論(0)  編輯  收藏 所屬分類: J2SE技術雜談
    主站蜘蛛池模板: 永久免费AV无码国产网站| 免费国产黄网站在线观看可以下载| 亚洲国产高清视频在线观看| 99久久精品国产亚洲| 亚洲综合小说久久另类区| 亚洲国产精品美女久久久久| 韩国免费A级毛片久久| 久久久久久夜精品精品免费啦 | 亚洲日韩欧洲乱码AV夜夜摸| 亚洲高清国产AV拍精品青青草原| 亚洲高清在线mv| 羞羞视频免费网站含羞草| 在线观看片免费人成视频播放| 久草视频免费在线| 亚洲日本一区二区三区在线不卡| 亚洲AV无码专区电影在线观看 | 中文字幕天天躁日日躁狠狠躁免费 | 男女交性无遮挡免费视频| 国产精品白浆在线观看免费| 免费高清av一区二区三区| 亚洲乱码中文字幕综合| 亚洲日韩一区二区一无码| 毛片在线播放免费观看| 亚洲AV无码乱码在线观看性色扶| 亚洲国产理论片在线播放| 精品国产污污免费网站入口在线| 岛国av无码免费无禁网站| 亚洲AV无码一区二区三区系列| 久久国产乱子伦精品免费不卡| 在线免费观看亚洲| 天天看片天天爽_免费播放| 亚洲色偷偷偷网站色偷一区| 在线a毛片免费视频观看| 亚洲视频在线免费| 免费国产不卡午夜福在线| 亚洲最大福利视频| 99在线在线视频免费视频观看| 亚洲av片不卡无码久久| 91福利免费体验区观看区| 亚洲国产精品无码久久九九大片| 亚洲一区无码精品色|