A股上市公司传智教育(股票代码 003032)旗下技术交流社区北京昌平校区

 找回密码
 加入黑马

QQ登录

只需一步,快速开始

© 七弦 中级黑马   /  2014-6-1 11:13  /  2727 人查看  /  5 人回复  /   0 人收藏 转载请遵从CC协议 禁止商业使用本文

毕老师讲的希尔排序大家能讲一下吗?简单一些说,思路要清晰!

5 个回复

正序浏览
额,没看懂,大神解释下
回复 使用道具 举报
啧啧太深奥
回复 使用道具 举报
chenzhiyuan 发表于 2014-6-1 20:54
那天我边做边理解了,但是现在貌似还写不出,这个数据结构比其他的难点,还得多敲这个代码,
那天照写一遍 ...

保存一下,回来看
回复 使用道具 举报
求积分哦,版主(美女)帅哥哦!
回复 使用道具 举报
那天我边做边理解了,但是现在貌似还写不出,这个数据结构比其他的难点,还得多敲这个代码,
那天照写一遍,在加独立写一遍,并且逐句的加了自己的理解,希望帮到你,加油!
        // 希尔排序
        public static void xierpaixu(int array[], int length) {// 10
                int len = length / 2;
                int i, j, temp;
                while (len >= 1) {// 每次都取它的中间下标, 循环的次数等于总长/2,除的次数
                        for (i = len; i < length; i++) {// 从5的下标循环到9下标

                                temp = array[i];// 保存值

                                j = i - len;// j是从0的下标变换到下标4
                                // 0到4的下标,每个值和temp比较,交换j和temp的值
                                while (j >= 0 && array[j] > temp) {// 如果0下标的值大于中间下标的值

                                        array[j + len] = array[j];// 0下标的值给中间的角标

                                        j = j - len;// 改变j的下标,这时j为负数,跳出循环
                                }
                                // 把j变成0的下标,给下标j赋值,j是当前循环时的下标,
                                array[j + len] = temp;
                        }

                        len = len / 2; // 缩小增量
                }
                for (int a = 0; a < length; a++) {// 遍历数组

                        System.err.print(array[a] + ",");

                }
        }

评分

参与人数 1技术分 +1 收起 理由
李小然 + 1

查看全部评分

回复 使用道具 举报 1 0
您需要登录后才可以回帖 登录 | 加入黑马