代码语言
.
CSharp
.
JS
Java
Asp.Net
C
MSSQL
PHP
Css
PLSQL
Python
Shell
EBS
ASP
Perl
ObjC
VB.Net
VBS
MYSQL
GO
Delphi
AS
DB2
Domino
Rails
ActionScript
Scala
代码分类
文件
系统
字符串
数据库
网络相关
图形/GUI
多媒体
算法
游戏
Jquery
Extjs
Android
HTML5
菜单
网页交互
WinForm
控件
企业应用
安全与加密
脚本/批处理
开放平台
其它
【
C/C++
】
Huffuman树
作者:
Alice
/ 发布于
2016/1/22
/
808
对于给定的一个数列,现在请你求出用该数列构造Huffman树的总费用,用STL实现; 例如,对于数列{pi}={5, 3, 8, 2, 9},Huffman树的构造过程如下: 1. 找到{5, 3, 8, 2, 9}中最小的两个数,分别是2和3,从{pi}中删除它们并将和5加入,得到{5, 8, 9, 5},费用为5。 2. 找到{5, 8, 9, 5}中最小的两个数,分别是5和5,从{pi}中删除它们并将和10加入,得到{8, 9, 10},费用为10。 3. 找到{8, 9, 10}中最小的两个数,分别是8和9,从{pi}中删除它们并将和17加入,得到{10, 17},费用为17。 4. 找到{10, 17}中最小的两个数,分别是10和17,从{pi}中删除它们并将和27加入,得到{27},费用为27。 5. 现在,数列中只剩下一个数27,构造过程结束,总费用为5+10+17+27=59。 #include"iostream" #include <cstring> #include <algorithm> #include <vector> using namespace std; int main(){ int n;//元素个数 int s=0;//总费用 cin>>n; vector<int>h; int temp; for(int i=0;i<n;i++){//输入 元素 cin>>temp; h.push_back(temp); } for(;;){ sort(h.begin(),h.end());//排序 temp=h[0]+h[1];//加法运算 s=s+temp;//获取费用 h.push_back(temp); sort(h.begin(),h.end());//再排序 h.erase(h.begin(),h.begin()+2);//删除 if(h.size()==1)break; } cout<<s<<endl; return 0; }
试试其它关键字
Huffuman
同语言下
.
C分鱼问题
.
链表
.
最大连续和
.
编码字符串
.
libiconv字符编码处理及判断字符串是否为utf8
.
一组数中两两二元组,差最大有几对,差最小呢?(数组
.
通过管道获取一个进程的执行状态
.
多关键字排序
.
字符串字典序排序
.
3元一次方程(牛顿迭代法求方程的根)
可能有用的
.
C#实现的html内容截取
.
List 切割成几份 工具类
.
SQL查询 多列合并成一行用逗号隔开
.
一行一行读取txt的内容
.
C#动态修改文件夹名称(FSO实现,不移动文件)
.
c# 移动文件或文件夹
.
c#图片添加水印
.
Java PDF转换成图片并输出给前台展示
.
网站后台修改图片尺寸代码
.
处理大图片在缩略图时的展示
Alice
贡献的其它代码
(
9
)
.
唤醒app
.
当鼠标移开时已弹出子菜单自动消失
.
加密解密相关
.
仿Discuz文本框弹出层的效果
.
IMAP 文件夹名称编码 解码
.
查看HTML代码
.
Huffuman树
.
判断字符串是否为纯数字
.
GridControl如何显示行号
Copyright © 2004 - 2024 dezai.cn. All Rights Reserved
站长博客
粤ICP备13059550号-3