码迷,mamicode.com
首页 > 编程语言 > 详细

希尔排序

时间:2017-09-01 01:00:33      阅读:245      评论:0      收藏:0      [点我收藏+]

标签:logs   shell   insert   data   希尔排序   change   希尔   nbsp   exchange   

 1 public class Solution 
 2 {
 3     public void shellSort(int[] data)
 4     {
 5         for(int i = data.length / 2; i > 0; i = i / 2)
 6         {
 7             for(int j = 0; j < i; j ++)
 8             {
 9                 insertSort(data, j, i);
10             }
11         }
12     }
13     
14     public void insertSort(int[] data, int begin, int distance)
15     {
16         for(int i = begin + distance; i < data.length; i = i + distance)
17         {
18             for(int j = i - distance; j >= 0; j = j - distance)
19             {
20                 if(data[j] > data[j + distance])
21                 {
22                     exchange(data, j, j + distance);
23                 }
24                 else
25                 {
26                     break;
27                 }
28             }
29         }
30     }
31     
32     public void exchange(int[] data, int m, int n)
33     {
34         int memory = data[m];
35         data[m] = data[n];
36         data[n] = memory;
37     }
38 }

 

希尔排序

标签:logs   shell   insert   data   希尔排序   change   希尔   nbsp   exchange   

原文地址:http://www.cnblogs.com/StringBuilder/p/7461176.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!