• 归并排序


    归并排序运行时间一定与NlogN成比例,运行时间仅与关键字数目有关系,与它们的顺序无关,因此归并排序是一种稳定的排序算法。归并排序另一个特点是它的执行过程中基本是按顺序访问数据的,比较适合使用链表排序。归并排序最主要的缺点是直接执行时需要与N成比例的额外内存空间(使用链表可以避免这种额外空间状况)。归并排序比快速排序优先之处是归并排序是稳定的算法,而且对任何输入文件执行的速度都很快,而它的不足之处是它需要使用和数组大小成比例的额外内存空间。当倾向使用归并排序且速度很重要时,需要考虑一些归并排序改进方法。

    对两个已排好序的文件,我们可以简单将它们合并成一个排好序的输出文件,分别取出两个输入文件中最小的数据,将这两个数据中较小的数放到输出文件中,循环操作,直到两个输入文件的数据项都已输出。

     1 template <class Item>
     2 void mergeAB(Item c[], Item a[], int N, Item b[], int M)
     3 {
     4     for (int i = 0, j = 0, k = 0; k < N+M; k++)
     5         {
     6              if (i == N) {c[k] = b[j++]; continue;}
     7              if (j == M) {c[k] = a[i++]; continue;}
     8              c[k] = (a[i] < b[j]) ? a[i++] : b[j++];
     9         }
    10 }
  • 相关阅读:
    Input(Checkbox)全选删除
    DropDownList查询&Input(Checkbox)查询
    分页(二)
    webform---组合查询&流水号生成
    (转)C#生成中文汉字验证码源码(webform)
    文件上传
    [转]用C#如何实现大文件的断点上传
    DOM操作----open()
    经典背包问题的探讨
    贪心算法----正整数分解问题 和相同,乘积最大
  • 原文地址:https://www.cnblogs.com/ningjing213/p/12186018.html
Copyright © 2020-2023  润新知