首页
Web开发
Windows程序
编程语言
数据库
移动开发
系统相关
微信
其他好文
会员
首页
>
其他好文
> 详细
C# 堆
时间:
2014-09-16 14:19:00
阅读:
127
评论:
0
收藏:
0
[点我收藏+]
标签:
数据结构
堆
c#
C# 堆
堆是一种非常有用的数据结构,下面的C#以插入数据的方式创建最大堆,然后实现了堆的插入和删除操作。
//构建最大堆,
public class MyHeap
{
List<int> heap = new List<int>();
int temp;
public MyHeap()
{
heap.Insert(0, -1);//第0位置保存数据-1,该数据无用
}
public void insertData(int d)
{
heap.Insert(heap.Count, d);
adjustUp(heap.Count-1);
}
//向上调整堆
private void adjustUp(int position)
{
//当前点的父节点数据小于当前点,则需要交换当前点父节点,接下来需要递归对当前点的父节点进行操作
if (Math.Floor((double)position / 2) > 0 && heap[(int)(Math.Floor((double)position / 2))] < heap[position])
{
exchange(position, (int)(Math.Floor((double)position / 2)));
adjustUp((int)(Math.Floor((double)position / 2)));
}
}
//向下调整堆
private void adjustDown(int position)
{
if (position * 2 < heap.Count && heap[position] < heap[position * 2])
{
exchange(position, position * 2);
adjustDown(position * 2);
}
else if (position * 2+1 < heap.Count && heap[position] < heap[position * 2+1])
{
exchange(position, position * 2+1);
adjustDown(position * 2+1);
}
}
private void exchange(int i,int j)
{
temp = heap[i];
heap[i] = heap[j];
heap[j] = temp;
}
//遍历找到第一个数值=d的节点i,将堆的最后一个节点挪到i处,向下递归调整i为根节点的堆
public void deleteData(int d)
{
int i =0;
for ( i = 1; i < heap.Count; i++)
{
if (heap[i] == d)
break;
}
if (i == heap.Count)
return;
else
{
heap[i] = heap[heap.Count - 1];
heap.RemoveAt(heap.Count - 1);
adjustDown(i);
}
}
public void printHeap()
{
for (int i = 1; i < heap.Count; i++)
{
Console.Write(heap[i] + " ");
}
}
}
下面是测试的程序:插入数据构建堆,然后删除数据。
MyHeap myheap = new MyHeap();
myheap.printHeap();
myheap.insertData(45);
myheap.insertData(36);
myheap.insertData(18);
myheap.insertData(53);
myheap.insertData(72);
myheap.insertData(30);
myheap.insertData(48);
myheap.insertData(93);
myheap.insertData(15);
myheap.insertData(35);
myheap.printHeap();
Console.WriteLine("");
Console.WriteLine("删除72");
myheap.deleteData(72);
myheap.printHeap();
Console.Read();
C# 堆
标签:
数据结构
堆
c#
原文地址:http://blog.csdn.net/luozuolincool/article/details/39315791
踩
(
0
)
赞
(
0
)
举报
评论
一句话评论(
0
)
登录后才能评论!
分享档案
更多>
2021年07月29日 (22)
2021年07月28日 (40)
2021年07月27日 (32)
2021年07月26日 (79)
2021年07月23日 (29)
2021年07月22日 (30)
2021年07月21日 (42)
2021年07月20日 (16)
2021年07月19日 (90)
2021年07月16日 (35)
周排行
更多
分布式事务
2021-07-29
OpenStack云平台命令行登录账户
2021-07-29
getLastRowNum()与getLastCellNum()/getPhysicalNumberOfRows()与getPhysicalNumberOfCells()
2021-07-29
【K8s概念】CSI 卷克隆
2021-07-29
vue3.0使用ant-design-vue进行按需加载原来这么简单
2021-07-29
stack栈
2021-07-29
抽奖动画 - 大转盘抽奖
2021-07-29
PPT写作技巧
2021-07-29
003-核心技术-IO模型-NIO-基于NIO群聊示例
2021-07-29
Bootstrap组件2
2021-07-29
友情链接
兰亭集智
国之画
百度统计
站长统计
阿里云
chrome插件
新版天听网
关于我们
-
联系我们
-
留言反馈
© 2014
mamicode.com
版权所有 联系我们:gaon5@hotmail.com
迷上了代码!