【NOI2015】荷马史诗

链接:http://uoj.ac/problem/130

因为不能有前缀关系,所以单词均为叶子节点,就是K叉哈夫曼树。第一问直接求解,第二问即第二关键字为树的高度。

#include< cstdio >
#include< algorithm > typedef unsigned long long ull;
template
inline void read(T&x)
{
x=0;bool f=0;char c=getchar();
while((c<'0'||c>'9')&&c!='-')c=getchar(); if(c=='-')f=1,c=getchar();
while(c>='0'&&c<='9'){x=x*10+c-'0';c=getchar();}
x=f?-x:x;
}
const int MAXN(100010);
struct Data
{
ull val;int dep;
inline bool operator <(const Data &A)const {return (val==A.val)?dep>A.dep:val>A.val;}
}h[MAXN],New;int top;
int n,k,First;ull Ans,sum,w[MAXN];
void umax(int &a,int b){if(a<b)a=b;}
int main()
{
// freopen("C.in","r",stdin);
// freopen("C.out","w",stdout);
read(n);read(k);
for(int i=1;i<=n;i++)read(w[i]),sum+=w[i];
for(int i=1;i<=n;i++)h[++top]=(Data){w[i],1};
std::make_heap(h+1,h+1+top);
First=(n-1)%(k-1) +1;
// printf("%d\n",First);
// printf("%llu\n",sum);
if(First>1||n==1)
{
for(int i=1;i<=First;i++)
{
New.val+=h[1].val;
Ans+=h[1].val;
umax(New.dep,h[1].dep);
std::pop_heap(h+1,h+1+top);top--;
}
New.dep++;h[++top]=New;
std::push_heap(h+1,h+1+top);
}
while(top>1)
{
New.val=New.dep=0;
for(int i=1;top&&i<=k;i++)
{
New.val+=h[1].val;
Ans+=h[1].val;
umax(New.dep,h[1].dep);
std::pop_heap(h+1,h+1+top);top--;
}
New.dep++;
// printf("%llu %d\n",New.val,New.dep);
h[++top]=New;
std::push_heap(h+1,h+1+top);
}
printf("%llu\n",Ans);
printf("%d\n",h[1].dep-1);
return 0;
}

最新文章

  1. Jenkins配置MSBuild实现自动部署(MSBuild+SVN/Subversion+FTP+BAT)
  2. java实现敏感词过滤(DFA算法)
  3. [LeetCode] Spiral Matrix 螺旋矩阵
  4. jQuery extend扩展String原型
  5. css3动态旋转魔方练习
  6. 深入了解try catch
  7. xampp3.2下mysql中文乱码终极解决方案
  8. SqlDataAdapter类
  9. HTML相关知识
  10. [AHOI2004]奇怪的字符串
  11. Hbase出现ERROR: Can&#39;t get master address from ZooKeeper; znode data == null正确找到解决思路
  12. PL/SQL学习笔记之函数
  13. 关于ICO的一些理解
  14. Yii2 Apache + Nginx 路由重写
  15. POJ 2393
  16. 微信小程序 - 自定义tabbar
  17. day21&lt;IO流+&amp;FIle递归&gt;
  18. Docker - CentOS 安装 Docker 和 Docker-Compose
  19. 滚动数组要来回赋初值呀。。orzzzzzzzzzzzzzzzzzzzzzzzzzz
  20. 图形数据库(GraphDB)

热门文章

  1. C# 中的EventHandler实例详解-转
  2. C# 字节转换
  3. PAT 1043【BST与二叉树】
  4. 关于写PPT
  5. Django 02 url路由配置及渲染方式
  6. Angular学习笔记之组件之间的交互
  7. spring定时任务的集中实现
  8. 练习四十六:列表排序,删除list中重复的元素
  9. postgresql 导出csv格式的数据后使用excel打开中文乱码的问题
  10. HDU - 5920 Ugly Problem 求解第一个小于n的回文数