zoukankan      html  css  js  c++  java
  • C#版排序之交换排序


    排序
    外部 内部
       
    交换排序 冒泡排序
    快速排序
    插入排序 直接插入排序
    希尔排序
    选择排序 直接选择排序
    堆排序
    归并排序 归并排序
    分配排序 箱排序
    基数排序

    排序:
           就是要整理文件中的记录,使之按关键字递增(或递减)次序排列起来。其确切定义如下:
          输入:n个记录R1,R2,…,Rn,其相应的关键字分别为K1,K2,…,Kn
          输出:Ril,Ri2,…,Rin,使得Ki1≤Ki2≤…≤Kin。(或Ki1≥Ki2≥…≥Kin)。
    外部排序:
          排序过程中要进行数据的内、外存交换。
    内部排序:
         在排序过程中,整个文件都是放在内存中处理,排序时不涉及数据的内、外存交换。
    外部排序:
         排序过程中要进行数据的内、外存交换
    交换排序:
         两两比较待排序记录的关键字,发现两个记录的次序相反时即进行交换,直到没有反序的记录为止。
    冒泡排序:
         将被排序的记录数组R[1..n]垂直排列,每个记录R[i]看作是重量为R[i].key的气泡。根据轻气泡不能在重气泡之下的原则,从下往上扫描数组R:凡扫描到违反本原则的轻气泡,就使其向上"飘浮"。如此反复进行,直到最后任何两个气泡都是轻者在上,重者在下为止。
    快速排序
       分治法的基本思想
         将原问题分解为若干个规模更小但结构与原问题相似的子问题。递归地解这些子问题,然后将这些子问题的解组合为原问题的解。
       快速排序的基本思想
         设当前待排序的无序区为R[low..high],利用分治法可将快速排序的基本思想描述为:
         在R[low..high]中任选一个记录作为基准(Pivot),以此基准将当前无序区划分为左、右两个较小的子区间R[low..pivotpos-1)和R[pivotpos+1..high],并使左边子区间中所有记录的关键字均小于等于基准记录(不妨记为pivot)的关键字pivot.key,右边的子区间中所有记录的关键字均大于等于pivot.key,而基准记录pivot则位于正确的位置(pivotpos)上,它无须参加后续的排序。

    冒泡排序与快速排序
  • 相关阅读:
    PHP vscode+XDebug 远程断点调试服务器上的代码
    Wordpress 为用户或角色 role 添加 capabilities(权限)
    Wordpress 后台文章编辑区添加模板选择功能
    CentOS 7 编译安装最新版git
    WordPress 通过文章 URL 获取文章 ID
    Web 安全问题 rel="noopener nofollw"
    Wordpress 通过 post id 获取文章 url
    git放弃修改&放弃增加文件
    Wordpress 作者模板页中的自定义帖子类型分页问题
    PHP 删除 url 中的 query string
  • 原文地址:https://www.cnblogs.com/tenghoo/p/751608.html
Copyright © 2011-2022 走看看