京东2017校园招聘笔试真题(希尔排序)

对关键字{10,20,8,25,35,6,18,30,5,15,28}序列进行希尔排序,取增量d =5时,排序结果为( )

A. {6,18,8,5,15,10,20,30,25,35,28}
B. {10,18,8,5,15,6,20,30,25,35,28}
C. {10,20,8,5,15,6,18,30,25,35,28}
D. {10,20,30,5,8,6,15,18,25,28,35}

希尔排序

希尔排序(Shell Sort)是插入排序的一种。也称缩小增量排序,是直接插入排序算法的一种更高效的改进版本。希尔排序是非稳定排序算法。该方法因DL.Shell于1959年提出而得名。

希尔排序是把记录按下标的一定增量分组,对每组使用直接插入排序算法排序;随着增量逐渐减少,每组包含的关键词越来越多,当增量减至1时,整个文件恰被分成一组,算法便终止。

JAVA代码实现

实现方式一:

public class ShellSort {
    public static void main(String [] args)
    {
        int[]a={49,38,65,97,76,13,27,49,78,34,12,64,1};
        System.out.println("排序之前:");
        for(int i=0;i<a.length;i++)
        {
            System.out.print(a[i]+" ");
        }
        //希尔排序
        int d=a.length;
            while(true){
                for(int i=0;i<d;i++){
                    for(int j=i;j+d<a.length;j+=d){
                    int temp;
                    if(a[j]>a[j+d]){
                        temp=a[j];
                        a[j]=a[j+d];
                        a[j+d]=temp;
                        }
                    }
                }
                if(d==1){break;}
                d--;
            }
            System.out.println();
            System.out.println("排序之后:");
            for(int i=0;i<a.length;i++)
            {
                System.out.print(a[i]+" ");
            }
        }
}

实现方式二:

package com.util;
public class ShellSort {
    public static void main(String [] args)
    {
        int[]a={49,38,65,97,76,13,27,49,78,34,12,64,1};
        System.out.println("排序之前:");
        for(int i=0;i<a.length;i++)
        {
            System.out.print(a[i]+" ");
        }
        //希尔排序
        int d=a.length;
        while(true)
            {
                d=d/2;
                for(int x=0;x<d;x++)
                {
                    for(int i=x+d;i<a.length;i=i+d)
                    {
                        int temp=a[i];
                        int j;
                        for(j=i-d;j>=0&&a[j]>temp;j=j-d)
                        {
                            a[j+d]=a[j];
                        }
                        a[j+d]=temp;
                    }
                }
                if(d==1)
                {
                    break;
                }
            }
            System.out.println();
            System.out.println("排序之后:");
            for(int i=0;i<a.length;i++)
            {
                System.out.print(a[i]+" ");
            }
        }
}
时间: 2024-10-22 07:40:49

京东2017校园招聘笔试真题(希尔排序)的相关文章

2017 携程 笔试编程题 1

前言 正文 题目要求 思路 n10 n 18 核心 测试 总结 前言 今天参加了携程的笔试,编程题第一题一开始想错了方向,花费了很多时间(虽然第二题就是给时间也不一定做得出来,(⊙﹏⊙)b). 下面记录一下这个小插曲. 正文 题目要求 将指定的正整数n分解成若干个互不相同的自然数的和,且使这些自然数的乘积最大 人家给了个输入输出的例子,如下: 输入15 输出 144 言下之意就是在自然数之和为15的这些数字中,乘积最大的一对是 2 3 4 6 思路 为了使得这些自然数之和的乘积最大,那么这些数字

软件测试工程师-meitu(2014年校园招聘笔试)

[历年IT笔试题]2014微软校园招聘笔试试题

2014Microsoft 校招笔试真题(找工作的虾米们赶紧做题晒答案喽)

阿里巴巴校园招聘笔试(答案版)

1. 一架飞机在满油的情况下可以绕地球飞 0.5 圈,假设飞机与飞机之间可以互相加油,请问在确保所有飞机够油飞回起点的情况下,最少需要几架飞机才可以让其中一架飞机成功绕地球飞行一圈? (提示1:地球是圆的!提示2:飞机可以重复使用!)  D A:3 B:4 C:5 D:6 E:7 2. 100 张多米诺骨牌整齐地排成一列,依顺序编号为 1.2.3.--.99.100 .第一次拿走所有奇数位置上的骨牌,第二次再从剩余骨牌中拿走所有奇数位置上的骨牌,以此类推.请问最后剩下的一张骨牌的编号是多少? B

[历年IT笔试题]2014阿里巴巴9月14北京校园招聘笔试及参考答案

[历年IT笔试题]2014腾讯校园招聘笔试试题

2011-10-15腾讯校园招聘笔试题目与参考答案

这里的题目收集于网上,真实信应该是真的   1,下列排序算法中,初始数据集的排序程序对算法性能无影响的是() A,插入排序B,堆排序 C,冒泡排序,D,快速排序  答案:B,冒泡的复杂度恒定为O(n^2),插入排序最差是O(n^2),最优化为O(n);堆排序建堆的时间是O(n),但是,排序的过程是O(nlogn),固定不变; 冒泡排序虽然大家都认为是O(n^2),但是,优化的冒泡是使用一个flag的,如果flag不变,说明不需要 再交换元素了,最优可以到O(n),快速排序不解释,最差的情况每一次

2015百度校招笔试真题以及解析(二)

1.static关键字,static全局变量与普通全局变量的区别,static局部变量与普通变量的区别,static函数与普通函数的区别. 全局变量(外部变量)的说明之前再冠以static 就构成了静态的全局变量.全局变量本身就是静态存储方式, 静态全局变量当然也是静态存储方式. 这两者在存储方式上并无不同.这两者的区别在于非静态全局变量的作用域是整个源程序,当一个源程序由多个源文件组成时,非静态的全局变量在各个源文件中都是有效的. 而静态全局变量则限制了其作用域, 即只在定义该变量的源文件内有