庞大资源库的计算机教程网站!
设为首页
加入收藏
总编信箱
投稿或申请专栏请先 [登 陆]
首页 操作系统 程序设计 图形图像 媒体动画 机械电子 WEB开发 数 据 库 办公系列 路由技术 网络原理 网络应用
认证考试 安全技术
首页>程序设计>C#语言>经典算法>正文
资料搜索
Google搜索
Google
返回上级列表

推荐文章

快速保存网页中所有图片的方法
Windows中让光驱巧妙“隐身”技
防范非法用户入侵Win 2000/XP系
两款比较典型的ASP木马防范方法
有关表格边框的css语法整理
Windows XP中可以被禁用的服务
SQL Server导出导入数据方法
Javascript所有对象的属性的获
网页(HTML)中的特殊字符
与篮球共舞,尽显模式本色
QQ病毒的手工清除方法
Photoshop为极品美女打造性感睫
天衣无缝:IIS与PHP水火也相容
SQL Server存储过程编写和优化

数据结构与算法(C#实现)系列---二叉堆(数组实现)

 作者:本站收集   日期:2005-8-8 10:08:41
字号选择〖 〗/ 双击滚屏 单击停止   

           数据结构与算法(C#实现)系列---二叉堆(数组实现)

using System;

using System.Collections;

 

namespace DataStructure

{

     /// <summary>

     /// BinaryHeap 的摘要说明。-------二叉堆(基于数组的实现)

     /// </summary>

     public class BinaryHeap:IPriorityQueue

     {

         protected ArrayList array;

         //建立一个最多容纳_length个对象的空二叉堆

         public BinaryHeap(uint _length)

         {

              //

              // TODO: 在此处添加构造函数逻辑

              //

              array=new ArrayList((int)_length);

              array.Capacity=(int)_length;

             

         }

         //堆中对象个数

         public virtual int Count{get{return this.array.Count;}}

         //将成员数组变成用1为基数表达的形式

         public virtual object Item(int _i)

         {

              if(_i>=this.array.Capacity)

                   throw new Exception("My:out of index");//不能出界

              return this.array[_i-1];

         }

         #region IPriorityQueue 成员

 

         //先将空洞放在数组的下一个位置上,也就是i(注:基数是1),然后和[i/2]位置上的数比较,如果小于则将空洞上移到[i/2]位置,而原先[i/2]位置上的对象则移到[i]上,否则就将空洞变为_obj----如此递归

         public void Enqueue(Object _obj)

         {

              // TODO:  添加 BinaryHeap.Enqueue 实现

              if( this.array.Count==this.array.Capacity )

                   throw new Exception("My:priority queue is full");//如果优先队列已满,则抛出异常

              this.array.Add(new object());

              int i=this.array.Count;

              while(i>1&&Comparer.Default.Compare(this.array[i/2-1],_obj  )>0)

              {

                   //this.Item(i)=this.Item(i/2);

                   this.array[i-1]=this.array[i/2-1];

                   i/=2;

              }

              this.array[i-1]=_obj;

         }

 

         public object FindMin()

         {

              // TODO:  添加 BinaryHeap.FindMin 实现

              if( this.array.Count==0 )

                   throw new Exception("My:priority queue is empty");//如果队列是空的,则抛出异常

              return this.array[0];

         }

 

         public object DequeueMin()

         {

              // TODO:  添加 BinaryHeap.DequeueMin 实现

              object tmpObj=this.FindMin();

              int i=1;

              while( (2*i+1)<=this.array.Count)

              {

                   if( Comparer.Default.Compare(this.array[2*i-1],this.array[2*i])<=0 )

                   {

                       this.array[i-1]=this.array[2*i-1];

                       this.array[2*i-1]=tmpObj;

                       i=2*i;

                   }

                   else

                   {

                       this.array[i-1]=this.array[2*i];

                       this.array[2*i]=tmpObj;

                       i=2*i+1;

                   }

              }

              object delObj=this.array[i-1];//暂时储存要删去的元素

              if(i!=this.array.Count)//如果搜索到的对象就是数组的最后一个对象,则什么都不要做

              {

                   this.array[i-1]=this.array[this.array.Count-1];//添补空洞

              }

              this.array.RemoveAt(this.array.Count-1);//将最后一个对象删除

 

              return delObj;

        

         }

 

         #endregion

     }

}

上一篇:数据结构与算法(C#实现)系列---二叉树    下一篇:C#冒泡算法  
[发送给好友]  [关闭窗口]  [返回顶部]   转载请注明来源:www.it00.com   
特别声明: 本站除部分特别声明禁止转载的专稿外的其他文章可以自由转载,但请务必注明出处和原始作者。文章版权归文章原始作者所有。对于被本站转载文章的个人和网站,我们表示深深的谢意。如果本站转载的文章有版权问题请联系编辑人员,我们尽快予以更正。
责任编辑: 原点 投稿作者: 本站收集
信息来源: 网络 录入时间: 2005-8-8 10:08:41
关于我们 - 广告服务 - 版权申明 - 网站地图 - 联系方式 - 总编信箱 - 会员投稿