2021牛客暑期多校训练营3A-Guess and lies【dp】

正题

题目链接:https://ac.nowcoder.com/acm/contest/11254/A


题目大意

现在有一个y∈[1,n]y\in[1,n]y[1,n]BobBobBob每次可以选择问AliceAliceAlice是否y≥xy\geq xyxAliceAliceAlice可以说一次谎。BobBobBob要在最少次数内确定yyy的值,而AliceAliceAlice尽量使得次数最多。

现在已知第一次BobBobBob询问的是kkkAliceAliceAlice回答了是,对于k∈[1,n]k\in[1,n]k[1,n]求每个kkk BobBobBob需要的最少询问次数。

1≤n≤20001\leq n\leq 20001n2000


解题思路

dlsdlsdls 在 WC 讲的神仙题目。

对于一种情况,假设y=iy=iy=i时,AliceAliceAlice说谎的次数是固定的,记这个次数为aia_iai,所以如果当1∼n1\sim n1n中只有一个数字满足ai≤1a_i\leq 1ai1时那么答案就是这个数字了。

然后看BobBobBob的操作,它每次可以选择一个xxxAliceAliceAlice可以选择让≥x\geq xx的数字或者让<x<x<x的数字的位置ai=ai+1a_i=a_i+1ai=ai+1BobBobBob需要用最少的次数使得只有一个位置ai≤1a_i\leq 1ai1

发现因为每次都是覆盖一个前缀或者一个后缀,所以如果只保留ai=0/1a_i=0/1ai=0/1的话那么所有的状态肯定是若干个111+若干个000+若干个111,分别记为a/b/ca/b/ca/b/c个,我们就可以设状态为fa,b,cf_{a,b,c}fa,b,c进行转移。

考虑到随着ccc的增大我们肯定会尽量选择中间的位置,也就是决策位置是单调递增的,所以我们可以做到O(n3)O(n^3)O(n3)的转移。

然后注意到这个和猜数字的规则很像,询问次数级别不会超过log⁡n\log nlogn,所以我们可以考虑交换次数和一个值域,记fw,a,bf_{w,a,b}fw,a,b表示猜测了www次能够猜出来的aaa000+bbb111+ccc000中最大的ccc,然后用决策单调性转移。

时间复杂度:O(n2log⁡n)O(n^2\log n)O(n2logn)


code

	#include<cstdio>#include<cstring>#include<algorithm>using namespace std;const int N=2100;int n,inf,f[20][N][N];int calc(int u,int v){int ans=19;while(ans&&f[ans-1][u][v]>=0)ans--;return ans;}int main(){scanf("%d",&n);memset(f,0xcf,sizeof(f));inf=f[0][0][0];for(int i=0;i<=1;i++)for(int j=0;j<=1-i;j++)f[0][i][j]=1-i-j;for(int i=1;i<=19;i++){for(int j=0;j<=n;j++)for(int k=0;k<=j;k++){int u=f[i-1][j-k][k];int v=f[i-1][k][j-k];if(u!=inf&&v!=inf){u=min(u,n-j);f[i][u][j]=max(f[i][u][j],v);}}for(int j=0;j<=n;j++){int v=f[i-1][j][0];if(v!=inf){for(int k=0;k<=n-j;k++){int u=f[i-1][k][j];if(u==inf)break;f[i][min(u,n-j)][j]=max(f[i][min(u,n-j)][j],v+k);f[i][min(v+k,n-j)][j]=max(f[i][min(v+k,n-j)][j],u);}}}for(int j=0;j<=n;j++)for(int k=n-j-1;k>=0;k--)f[i][k][j]=max(f[i][k][j],f[i][k+1][j]);}for(int i=0;i<n;i++)printf("%d ",calc(i,n-i));return 0;}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/317539.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

CF453C:Little Pony and Summer Sun Celebration(dfs、构造)

解析 比较巧妙的一道题 首先做一棵dfs生成树出来 尝试把它的欧拉序列作为答案 但是这样可能会有的地方不符合条件 如果x点的奇偶性不符合&#xff0c;就在序列中加入一个(x,fa) 同时改变x和fa的奇偶性 显然不会超过4*n 如果根需要改奇偶性怎么办&#xff1f; 最后一次回溯删掉…

开源中国 2018 新增开源软件最受欢迎 TOP 50

本周开源中国陆续公布了两个年度榜单&#xff0c;分别是国产新秀榜 TOP 30 和国产新增榜 TOP 50。由于两个榜单的数据来源都是国内开源项目&#xff0c;所以会有部分项目同时出现在两个榜单上。今天公布的这份榜单 —— 开源中国 2018 新增开源软件最受欢迎 TOP 50&#xff0c;…

简单环题解

简单环 题解: 题目求环的情况 如果我们直接枚举会有很多重复&#xff0c;为了避免重复&#xff0c;我们枚举起点&#xff0c;其他的点的序号都必须比起点大&#xff0c;也就是x->y&#xff0c;x一定小于y dp[i][j]表示的是以i的第一个点作为起点的链的数量&#xff0c;j是…

AT2339-[AGC011C]Squared Graph【黑白染色】

正题 题目链接:https://www.luogu.com.cn/problem/AT2339 题目大意 给出nnn个点mmm条边的一张无向图&#xff0c;然后有一张nnn\times nnn的图&#xff0c;每个点是一个二元组(a,b)(a,b)(a,b)。(a,b)(a,b)(a,b)和(c,d)(c,d)(c,d)连边当且仅当aaa和ccc有连边&#xff0c;bbb和…

[树链剖分]List wants to travel,Relief grain,hotel加强版,This world need more Zhu

文章目录B&#xff1a;Relief grainC&#xff1a;hotel加强版B&#xff1a;Relief grain 题目 将一段区间修改的标记变成差分&#xff0c;每次都是连续一段的dfndfndfn序修改 从小到大枚举dfndfndfn&#xff0c;在一段标记的最开头的dfndfndfn插入&#xff0c;最末尾的dfndf…

P4342:[IOI1998]Polygon(区间dp)

一道警钟一样的好题 解析 乍一看&#xff1a; “这不就能量项链嘛&#xff0c;这也蓝&#xff1f;” 然后就愉快的WA掉了… qwq 让我们回归本源&#xff0c;在什么时候可以动态规划&#xff1f; “局部最优解可以带动全局最优解的时候&#xff0c;我们可以使用动态规划算法”…

eShopOnContainers 知多少[8]:Ordering microservice

1. 引言Ordering microservice&#xff08;订单微服务&#xff09;就是处理订单的了&#xff0c;它与前面讲到的几个微服务相比要复杂的多。主要涉及以下业务逻辑&#xff1a;订单的创建、取消、支付、发货库存的扣减2. 架构模式如上图所示&#xff0c;该服务基于CQRS 和DDD来实…

P4229-某位歌姬的故事【dp】

正题 题目链接:https://www.luogu.com.cn/problem/P4229 题目大意 求有多少个长度为nnn的序列aaa&#xff0c;满足∀i∈[1,n],ai∈[1,A]\forall i\in[1,n],a_i\in[1,A]∀i∈[1,n],ai​∈[1,A]&#xff0c;还有QQQ个限制形如 max⁡{aj}(j∈[li,ri])mi\max\{a_j\}(j\in[l_i,r_i…

Most Powerful

Most Powerful 题意&#xff1a; n个原子&#xff0c;当其中两个原子碰撞时&#xff0c;其中一个会消失&#xff0c;产生大量能量。现在知道每两个原子的碰撞表现&#xff0c;求出产生的能量总和的最大值 题解: 设dp[i]表示i状态下所获得的能量 i为二进制&#xff0c;第x位…

[树套树] 网络管理

A&#xff1a;[CTSC2008]网络管理 此题本来是平衡树板块的&#xff0c;但俺写的是树套树&#xff0c;平衡树会多个log 题目 查询第kkk大&#xff0c;天然主席树可以维护 就不用了平衡树二分&#xff0c;多个logloglog了 将树上(u,v)(u,v)(u,v)的路径转化为 uuu到根 vvv到根…

[翻译] Entity Framework Core in Action 关于这本书

Entityframework Core in action是 Jon P smith 所著的关于Entityframework Core 书籍。原版地址. 是除了官方文档外另一个学习EF Core的不错途径, 书中由浅入深的讲解的EF Core的相关知识。因为没有中文版,所以本人对其进行翻译。 预计每两天一篇更新 PS: 翻译难免限于本人水平…

CF573E-Bear and Bowling【dp,平衡树】

正题 题目链接:https://www.luogu.com.cn/problem/CF573E 题目大意 给出一个长度为nnn的序列aaa&#xff0c;求它的一个子序列bbb&#xff0c;要求最大化 ∑i1∣b∣bii\sum_{i1}^{|b|}b_i\times ii1∑∣b∣​bi​i 1≤n≤105,∣ai∣≤1071\leq n\leq 10^5,|a_i|\leq 10^71≤n…

NC51189 Mondriaan‘s Dream

NC51189 Mondriaan’s Dream 题意&#xff1a; n * m的矩阵&#xff0c;用1 * 2和2 * 1的砖快密铺&#xff0c;问多少种方法&#xff1a; 题解&#xff1a; 方法1&#xff1a; 我们现在规定砖头的竖放的上部分为1&#xff0c;砖头的横放或者是竖放的下部分为0 我们每两层进…

CF1408D:Searchlights

解析 滥用数据结构了属于是 本题的思路和题解还是差不多的 暴力枚举灯和海盗乱搞即可 但是最后对fif_ifi​的维护我使用了树状数组&#xff0c;凭空多了个log… 尽管树状数组跑的飞快 其实直接倒着扫一遍就行了 特殊数据下我这个算法是可以跑满n方log1e6的 过2000我在想peach…

[LCT动态树] [NOI2014]魔法森林,[ZJOI2018]历史

[NOI2014] 魔法森林 题目 按照aaa精灵从小到大排序 按顺序插入每一条边 加入第iii条边后的最小代价为a[i]a[i]a[i]加上从111到nnn的所有路径中最大bbb最小的路径代价 维护边权 把边在LCTLCTLCT中理解为点&#xff1f;——看题解代码其实就是建虚点 出现环时 选择最大的bb…

《小团队构建大网站:中小研发团队架构实践》送书活动结果公布

截止到1月25日24&#xff1a;00&#xff0c;本次送书活动共收到75位同学参与回复&#xff0c;本次很多同学在看到活动的书十年IT老兵带你通过案例学架构&#xff0c;附C#代码&#xff0c;自行就到各大网络商店上购买了书&#xff0c;据反馈这个书很不错.下面把Top 2的留言截图给…

P6466-分散层叠算法(Fractional Cascading)【模板】

正题 题目链接:https://www.luogu.com.cn/problem/P6466 题目大意 给出kkk个长度为nnn的有序序列&#xff0c;qqq次询问给出xxx&#xff0c;求所有序列中xxx的后继的异或和。 强制在线 1≤k≤100,1≤n≤104,1≤q≤51051\leq k\leq 100,1\leq n\leq 10^4,1\leq q\leq 5\times…

11.13模拟:总结

文章目录总结题目update&#xff08;solution of T3&#xff09;&#xff1a;代码230pts100100300总结 不要先入为主&#xff01;如果某种算法受阻&#xff0c;要尝试一下别的路子&#xff01;&#xff01; 本次的主要问题&#xff1a; T2花费时间略长&#xff08;指2h&#…

Strategic game(树的最小点覆盖)

Strategic game 题意&#xff1a; 一个树&#xff0c;在一个节点放兵&#xff0c;周围的边就被守护&#xff0c;守护所有的边&#xff0c;问最少放多少兵 题解&#xff1a; 这种问题又称树的最小点覆盖 dp[x][1]以x为根的子树全被看住且在x上放置士兵的最少所需的士兵数量 …

test6 3-21 2021省选模拟赛six

文章目录考试复盘rnglgpm考试复盘 第一题&#xff0c;乍一看期望&#xff0c;又不会做了&#xff0c;乍二看&#xff0c;暴力好像可以202020跑路&#xff0c;屁颠屁颠敲完死活过不了这个简单的样例&#xff1b;开始(⊙⊙?)乍三看&#xff0c;实数&#xff1f;&#xff1f;完了…