2012/10/01——凌乱的整理

本文介绍了多种经典的排序算法,包括快速排序、堆排序、计数排序和基数排序,并详细展示了它们的实现过程。此外,还涉及了散列表的多种处理碰撞的方法及二叉查找树等数据结构的基本概念。

(1)堆

MAX-HEAPIFY(A,i)

BUILD-MAX-HEAP(A)

HEAPSORT(A)

{

BUILD-MAX-HEAP(A)

for    lenth  downto 2  

  exchange  A[i]---A[1]

heapsize=heapsize-1

MAX-HEAPIFY(A,1)

}

优先队列的一些操作:

HEAP-EXTRACT-MAX(A)

HEAP-INCREACE-KEY(A,i,key)

MAX-HEAP-INSERT(A,key)

(2)快速排序

就地排序

QUICKSORT(A,p,r)

数组划分:

PARTITION(A,p,r)

x=A[r];

i=p-1;

for(j=p;j<r;j++)

{

if(A[j]<x)

  i++;

     exchange   A[j]-----A[i];

}

A[i+1]=x;

return i+1;

(3)计数排序

 COUNTING-SORT(A,B,k)

for(j=lenth(A);j>=1;j--)

  B[C[A[j]]]=A[j];

  C[A[j]]=C[A[j]]-1;

(4)基数排序

RADIX-SORT(A,d)

(5)散列表

  • 直接寻址表
  • 散列表

   (1)通过链接发解决碰撞  装载因子=n/m

   (2)除法散列法     h(k)=key mod 701

   (3)乘法散列法     h(k)=[m(kA  mod  1)]

  • 开放寻址法

    HASH-INSERT(T,k)

    (1)线性探查   h(k,i)=(h`(k)+i)mod m

    (2)二次探查  h(k,i)=(h`(k)+c1i+c2i*i)mod m

    (3)双重散列  h(k,i)=(h1(k)+h2(k))mod m

(6)二叉查找树

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

转载于:https://www.cnblogs.com/programmersong/archive/2012/10/01/2709760.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值