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)二叉查找树

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

posted @ 2012-10-01 15:48  画家与我  阅读(143)  评论(0编辑  收藏  举报