• linkedu视频
  • 平面设计
  • 电脑入门
  • 操作系统
  • 办公应用
  • 电脑硬件
  • 动画设计
  • 3D设计
  • 网页设计
  • CAD设计
  • 影音处理
  • 数据库
  • 程序设计
  • 认证考试
  • 信息管理
  • 信息安全
菜单
linkedu.com
  • 网页制作
  • 数据库
  • 程序设计
  • 操作系统
  • CMS教程
  • 游戏攻略
  • 脚本语言
  • 平面设计
  • 软件教程
  • 网络安全
  • 电脑知识
  • 服务器
  • 视频教程
  • JavaScript
  • ASP.NET
  • PHP
  • 正则表达式
  • AJAX
  • JSP
  • ASP
  • Flex
  • XML
  • 编程技巧
  • Android
  • swift
  • C#教程
  • vb
  • vb.net
  • C语言
  • Java
  • Delphi
  • 易语言
  • vc/mfc
  • 嵌入式开发
  • 游戏开发
  • ios
  • 编程问答
  • 汇编语言
  • 微信小程序
  • 数据结构
  • OpenGL
  • 架构设计
  • qt
  • 微信公众号
您的位置:首页 > 程序设计 >编程技巧 > 算法系列15天速成 第三天 七大经典排序【下】

算法系列15天速成 第三天 七大经典排序【下】

作者: 字体:[增加 减小] 来源:互联网 时间:2017-05-12

通过本文主要向大家介绍了算法系列15天速成 第三天 七大经典排序【下】等相关知识,希望对您有所帮助,也希望大家支持linkedu.com www.linkedu.com

直接插入排序:

       这种排序其实蛮好理解的,很现实的例子就是俺们斗地主,当我们抓到一手乱牌时,我们就要按照大小梳理扑克,30秒后,

   扑克梳理完毕,4条3,5条s,哇塞......  回忆一下,俺们当时是怎么梳理的。

       最左一张牌是3,第二张牌是5,第三张牌又是3,赶紧插到第一张牌后面去,第四张牌又是3,大喜,赶紧插到第二张后面去,

   第五张牌又是3,狂喜,哈哈,一门炮就这样产生了。

     怎么样,生活中处处都是算法,早已经融入我们的生活和血液。     

     下面就上图说明:             

      看这张图不知道大家可否理解了,在插入排序中,数组会被划分为两种,“有序数组块”和“无序数组块”,  

      对的,第一遍的时候从”无序数组块“中提取一个数20作为有序数组块。

     第二遍的时候从”无序数组块“中提取一个数60有序的放到”有序数组块中“,也就是20,60。

     第三遍的时候同理,不同的是发现10比有序数组的值都小,因此20,60位置后移,腾出一个位置让10插入。

     然后按照这种规律就可以全部插入完毕。

namespace InsertSort
{
    public class Program
    {
        static void Main(string[] args)
        {
            List<int> list = new List<int>() { 3, 1, 2, 9, 7, 8, 6 };

            Console.WriteLine("排序前:" + string.Join(",", list));

            InsertSort(list);

            Console.WriteLine("排序后:" + string.Join(",", list));
        }

        static void InsertSort(List<int> list)
        {
            //无须序列
            for (int i = 1; i < list.Count; i++)
            {
                var temp = list[i];

                int j;

                //有序序列
                for (j = i - 1; j >= 0 && temp < list[j]; j--)
                {
                    list[j + 1] = list[j];
                }
                list[j + 1] = temp;
            }
        }
    }
}
</div>

希尔排序:

        观察一下”插入排序“:其实不难发现她有个缺点:

              如果当数据是”5, 4, 3, 2, 1“的时候,此时我们将“无序块”中的记录插入到“有序块”时,估计俺们要崩盘,

       每次插入都要移动位置,此时插入排序的效率可想而知。   

      shell根据这个弱点进行了算法改进,融入了一种叫做“缩小增量排序法”的思想,其实也蛮简单的,不过有点注意的就是:

  增量不是乱取,而是有规律可循的。

首先要明确一下增量的取法:

      第一次增量的取法为: d=count/2;

      第二次增量的取法为:  d=(count/2)/2;

      最后一直到: d=1;

看上图观测的现象为:

        d=3时:将40跟50比,因50大,不交换。

                   将20跟30比,因30大,不交换。

                   将80跟60比,因60小,交换。

        d=2时:将40跟60比,不交换,拿60跟30比交换,此时交换后的30又比前面的40小,又要将40和30交换,如上图。

                   将20跟50比,不交换,继续将50跟80比,不交换。

        d=1时:这时就是前面讲的插入排序了,不过此时的序列已经差不多有序了,所以给插入排序带来了很大的性能提高。

既然说“希尔排序”是“插入排序”的改进版,那么我们就要比一下,在1w个数字中,到底能快多少?

下面进行一下测试:

namespace ShellSort
{
    public class Program
    {
        static void Main(string[] args)
        {
            //5次比较
            for (int i = 1; i <= 5; i++)
            {
                List<int> list = new List<int>();

                //插入1w个随机数到数组中
                for (int j = 0; j < 10000; j++)
                {
                    Thread.Sleep(1);
                    list.Add(new Random((int)DateTime.Now.Ticks).Next(10000, 1000000));
                }

                List<int> list2 = new List<int>();
                list2.AddRange(list);

                Console.WriteLine("\n第" + i + "次比较:");

          

分享到:QQ空间新浪微博腾讯微博微信百度贴吧QQ好友复制网址打印

您可能想查找下面的文章:

相关文章

  • 2017-05-12google提供二维码生成器
  • 2017-09-22HTTP状态码
  • 2017-12-31redis Fundication
  • 2017-08-31require-js-模块化使用教程
  • 2017-05-12json转String与String转json及判断对象类型示例代码
  • 2017-08-23FFmpeg基本介绍
  • 2017-05-12让开发自动化 用 Eclipse 插件提高代码质量
  • 2017-05-12php/asp/asp.net中判断百度移动和PC蜘蛛的实现代码
  • 2017-05-12浏览器缓存知识小结及应用分析
  • 2017-05-12编程之显示/隐式声明

文章分类

  • JavaScript
  • ASP.NET
  • PHP
  • 正则表达式
  • AJAX
  • JSP
  • ASP
  • Flex
  • XML
  • 编程技巧
  • Android
  • swift
  • C#教程
  • vb
  • vb.net
  • C语言
  • Java
  • Delphi
  • 易语言
  • vc/mfc
  • 嵌入式开发
  • 游戏开发
  • ios
  • 编程问答
  • 汇编语言
  • 微信小程序
  • 数据结构
  • OpenGL
  • 架构设计
  • qt
  • 微信公众号

最近更新的内容

    • 程序员学英语的一个方法
    • 静态方法(属性)与实例方法(属性)
    • 五个最佳编程文本编辑器分享
    • Git 教程之分支管理详解
    • 分享下GET和POST的真正区别
    • 简单谈谈GET和POST有什么区别
    • web服务器程序运行出现乱码问题的解决方法
    • php和js编程中的延迟执行效果的代码
    • 高性能WEB开发 web性能测试工具推荐
    • 奇怪的回车换行问题

关于我们 - 联系我们 - 免责声明 - 网站地图

©2020-2025 All Rights Reserved. linkedu.com 版权所有