Problem

辣鸡bzoj权限题,洛谷链接

题意概要:一棵 \(n\) 个点有根树。\(Q\) 次询问给出一个 \(K\),回答遍历完整棵树所需最少操作次数。每次操作可以选择访问不超过 \(K\) 个未访问的点,且这些点的父亲必须在之前被访问过。

Solution

一开始题意理解错了,以为同时段每个点都能扩展 \(k\) 次,然后就无耻地看了题解……但是有个证明网上都没写,这也正是写这篇博客的原因

大概意思是说,最优策略一定是先用 \(i\) 步取完前 \(i\) 层,然后选取剩下深度大于 \(i\) 的节点时每次都能取满。规范一下就是设 \(s[i]\) 表示深度大于 \(i\) 的节点个数,则答案为 \(\max\limits_{i=1}^n \{i+\lceil \frac {s[i]}k\rceil\}\)

然后就可以正常斜率优化了:维护点 \((i,s[i])\) 的上凸包,每次询问 \(i\) 则在凸包上找斜率为 \(-i\) 的直线所切的点

但是看题解的时候不清楚前边那个式子的正确性,为什么会存在一条分界线使得上面可以用 \(i\) 次选完 \(i\) 层,下面可以随意选

思考了一会才弄懂,对于一棵树,从底层选择一个最深的深度 \(d\),显然满足下部节点可以随意选择(目前没有下部节点),但是有可能上部节点不能在层数次内选完。若出现这种情况,则上部一定存在若干层节点特别多,导致无法消完,可以考虑将分界线挪到某一层的上一层,由于这层节点特别多,可以保证下部节点可以随意选择。所以存在分界线比深度 \(d\) 浅,将 \(d\) 减小继续判断直到无法挪动,则找到分界线

至于为什么 \(\max\limits_{i=1}^n \{i+\lceil \frac {s[i]}k\rceil\}\) 中取最大值即可,是因为如若没有选择到分界线,则算出的值一定比最终答案要小

Code

  1. #include <bits/stdc++.h>
  2. using namespace std;
  3. typedef long long ll;
  4. typedef double db;
  5. template <typename _tp> inline void read(_tp&x){
  6. char c11=getchar();x=0;while(!isdigit(c11))c11=getchar();
  7. while(isdigit(c11))x=x*10+c11-'0',c11=getchar();
  8. }
  9. const int N = 1001000;
  10. struct Edge{int v,nxt;} a[N+N];
  11. int head[N], s[N], Ans[N], qy[N];
  12. ll f[N];
  13. int n,Q,tp,_,mxd;
  14. void dfs(int x,int ds){
  15. ++s[ds], mxd = max(mxd, ds);
  16. for(int i=head[x];i;i=a[i].nxt)
  17. dfs(a[i].v,ds+1);
  18. }
  19. struct vec{
  20. ll x,y;
  21. inline void in(){read(x), read(y);}
  22. friend inline vec operator - (const vec&A,const vec&B) {return (vec){A.x - B.x, A.y - B.y};}
  23. friend inline db operator * (const vec&A,const vec&B) {return (db)A.x * B.y - (db)A.y * B.x;}
  24. friend inline bool operator < (const vec&A,const vec&B) {return A.x!=B.x ? A.x<B.x : A.y>B.y;}
  25. }p[N],stk[N];
  26. int main(){
  27. read(n), read(Q);
  28. for(int i=1;i<=Q;++i) read(qy[i]);
  29. for(int i=2,x;i<=n;++i) read(x), a[++_].v = i, a[_].nxt = head[x], head[x] = _;
  30. dfs(1,0);
  31. for(int i=n;~i;--i) s[i] += s[i+1];
  32. for(int i=0;;++i){
  33. vec nw = (vec) {i, s[i]};
  34. while(tp > 1 and (stk[tp] - stk[tp-1]) * (nw - stk[tp]) >= 0) --tp;
  35. stk[++tp] = nw;
  36. if(!s[i]) break;
  37. }
  38. for(int i=1,t=1;i<=n;++i){
  39. vec dir = (vec) {1, -i};
  40. while(t < tp and (stk[t+1] - stk[t]) * dir < 0) ++t;
  41. Ans[i] = (stk[t].y + (ll)i * stk[t].x + i-1) / i;
  42. }
  43. ++mxd;
  44. for(int i=1;i<=Q;++i){
  45. if(Ans[qy[i]]) printf("%d ",Ans[qy[i]]);
  46. else printf("%d ",mxd);
  47. }
  48. return 0;
  49. }

题解-POI2014 Supercomputer的更多相关文章

  1. 【BZOJ】3835: [Poi2014]Supercomputer

    题意 \(n(1 \le 1000000)\)个点的有根树,\(1\)号点为根,\(q(1 \le 1000000)\)次询问,每次给一个\(k\),每一次可以选择\(k\)个未访问的点,且父亲是访问 ...

  2. BZOJ3835: [Poi2014]Supercomputer

    Description Byteasar has designed a supercomputer of novel architecture. It may comprise of many (id ...

  3. BZOJ3835[Poi2014]Supercomputer——斜率优化

    题目描述 Byteasar has designed a supercomputer of novel architecture. It may comprise of many (identical ...

  4. BZOJ3835 [Poi2014]Supercomputer 【斜率优化】

    题目链接 BZOJ3835 题解 对于\(k\),设\(s[i]\)为深度大于\(i\)的点数 \[ans = max\{i + \lceil \frac{s[i]}{k}\} \rceil\] 最优 ...

  5. 题解-POI2014 FAR-FarmCraft

    Problem bzoj权限题,洛谷上可提交 洛谷上的奇葩翻译不要看,很多条件缺漏 题意简述:给定一棵树,每条边权为1,给定所有点点权,每条边仅能走两次,求以一定顺序遍历整棵树后,使所有点中的到达时间 ...

  6. [POI2014]Supercomputer

    题目大意: 给定一个$n(n\le10^6)$个结点的有根树,从根结点开始染色.每次可以染和已染色结点相邻的任意$k$个结点.$q(q\le10^6)$组询问,每次给定$k$,问至少需要染几次? 思路 ...

  7. POI2014题解

    POI2014题解 [BZOJ3521][Poi2014]Salad Bar 把p当作\(1\),把j当作\(-1\),然后做一遍前缀和. 一个合法区间\([l,r]\)要满足条件就需要满足所有前缀和 ...

  8. bzoj AC倒序

    Search GO 说明:输入题号直接进入相应题目,如需搜索含数字的题目,请在关键词前加单引号 Problem ID Title Source AC Submit Y 1000 A+B Problem ...

  9. BZOJ3524 & LOJ2432:[POI2014]代理商Couriers——题解

    https://www.lydsy.com/JudgeOnline/problem.php?id=3524 https://loj.ac/problem/2432 给一个长度为n的序列a.1≤a[i] ...

随机推荐

  1. Python----简单线性回归

    简单线性回归 1.研究一个自变量(X)和一个因变量(y)的关系   简单线性回归模型定义:y=β0+β1x+ε 简单线性回归方程:E(y)=β0+β1x 其中: β0为回归线的截距 β1为回归线的斜率 ...

  2. [references] How to Do Research

    目录: ** 0x01 做研究/写论文的Alpha/Beta ** 0x02 How to Do Research | 经典指南 ** 0x03 思考写作与研究的区别 | The difference ...

  3. MediaManager安装后配置

    端口要改成81 修改Chainmail名称:

  4. yolov3和darknet opencv版编译安装及基本测试

    版权声明:本文为博主原创文章,欢迎转载,并请注明出处.联系方式:460356155@qq.com 一.准备工作: 安装pkg-config:sudo apt-get install pkg-confi ...

  5. [安全转帖]浅析安全威胁情报共享框架OpenIOC

    浅析安全威胁情报共享框架OpenIOC https://www.freebuf.com/sectool/86580.html Indicator of compromise Outline: 1. I ...

  6. Django(八)上:Model操作和Form操作

    ↑↑↑点上面的”+”号展开目录 Model和Form以及ModelForm简介 Model操作: 创建数据库表结构 操作数据库表 做一部分的验证 Form操作: 数据验证(强大) ModelForm ...

  7. 【调试工具】tcpdump

    [tcpdump]https://linux.cn/article-10191-1.html

  8. Maven版本不一致的时候,使用指定版本进行编译

    最近用Maven打包项目(本地jdk11)后放到服务器(jdk8)后,报[java.lang.UnsupportedClassVersionError]版本不一致错误. 网上资料说是修改Intelli ...

  9. Go语言中数组

    数组是一个值类型 func ArrayTest1(){ var arryA [3]int = [3]int{1,2,3} //创建一个数组B,将B中第二个元素设置为200 arryB := arryA ...

  10. tcpdump常用参数说明及常见操作

    tcpdump常用参数说明及常见操作 -a 将网络地址和广播地址转变成名字 -c 指定抓包的数量 -d 将匹配信息包的代码以人们能够理解的汇编格式给出 -dd 将匹配信息包的代码以c语言程序段的格式给 ...