牛客练习赛 57——manacher算法 树形dp?

A - Tic-Tac-Toe

直接考虑每个人8种赢的情况即可。

#define IO ios::sync_with_stdio(false);cin.tie();cout.tie(0)
#pragma GCC optimize(2)
#include<iostream>
#include<algorithm>
using namespace std;
const int N=5;
char g[N][N];
int main()
{//IO;int T=1;cin>>T;while(T--){for(int i=1;i<=3;i++) cin>>g[i]+1;bool ok1=0,ok2=0;if(g[1][1]=='A'&&g[1][2]=='A'&&g[1][3]=='A') ok1=1;if(g[2][1]=='A'&&g[2][2]=='A'&&g[2][3]=='A') ok1=1;if(g[3][1]=='A'&&g[3][2]=='A'&&g[3][3]=='A') ok1=1;if(g[1][1]=='A'&&g[2][1]=='A'&&g[3][1]=='A') ok1=1;if(g[1][2]=='A'&&g[2][2]=='A'&&g[3][2]=='A') ok1=1;if(g[1][3]=='A'&&g[2][3]=='A'&&g[3][3]=='A') ok1=1;if(g[1][1]=='A'&&g[2][2]=='A'&&g[3][3]=='A') ok1=1;if(g[1][3]=='A'&&g[2][2]=='A'&&g[3][1]=='A') ok1=1;if(g[1][1]=='B'&&g[1][2]=='B'&&g[1][3]=='B') ok2=1;if(g[2][1]=='B'&&g[2][2]=='B'&&g[2][3]=='B') ok2=1;if(g[3][1]=='B'&&g[3][2]=='B'&&g[3][3]=='B') ok2=1;if(g[1][1]=='B'&&g[2][1]=='B'&&g[3][1]=='B') ok2=1;if(g[1][2]=='B'&&g[2][2]=='B'&&g[3][2]=='B') ok2=1;if(g[1][3]=='B'&&g[2][3]=='B'&&g[3][3]=='B') ok2=1;if(g[1][1]=='B'&&g[2][2]=='B'&&g[3][3]=='B') ok2=1;if(g[1][3]=='B'&&g[2][2]=='B'&&g[3][1]=='B') ok2=1;if(ok1&&ok2) cout<<"invalid\n";else if(ok1) cout<<"Yes\n";else if(ok2) cout<<"No\n";else cout<<"draw\n";}return 0;
}

B - 打 boss

如果第一次都能打死就不考虑回复血的情况
如果第一次打不死并且回血不少于掉血肯定永远打不死
人死之前最多能攻击⌈h1a2⌉\lceil\frac{h_1}{a_2} \rceila2h1次,如果死之前打不死(需要干掉h2+m⌈h1a2−1⌉h2+m\lceil\frac{h_1}{a_2}-1 \rceilh2+ma2h11血量)那么就打不死,否则能打死。

#define IO ios::sync_with_stdio(false);cin.tie();cout.tie(0)
#pragma GCC optimize(2)
#include<set>
#include<map>
#include<cmath>
#include<queue>
#include<string>
#include<vector>
#include<cstdio>
#include<cstring>
#include<iostream>
#include<algorithm>
#include<unordered_map>
using namespace std;
typedef long long ll;
typedef pair<int,int> pii;
int main()
{IO;int T=1;cin>>T;while(T--){ll h1,h2;ll a1,a2;ll m;cin>>h1>>h2>>a1>>a2>>m;if(h2<=a1) cout<<"Yes\n";else if(m>=a1) cout<<"No\n";else if(((h1+a2-1)/a2)*a1<h2+m*((h1+a2-1)/a2-1)) cout<<"No\n";else cout<<"Yes\n";}return 0;}

C - 装货物

搜索渣渣。没经历过偏分的oi没能成为搜索king

#define IO ios::sync_with_stdio(false);cin.tie();cout.tie(0)
#pragma GCC optimize(2)
#include<cstring>
#include<iostream>
#include<algorithm>
using namespace std;
const int N=30;
ll w[N];
int n,m,W;
ll now[N];
bool ok;
void dfs(int u,int cnt)
{if(ok) return;//这个优化直接让我过了if(u>n){ok=1;return;}for(int i=1;i<=cnt;i++){if(now[i]+w[u]<=W){now[i]+=w[u];dfs(u+1,cnt);now[i]-=w[u];}}if(w[u]<=W&&cnt+1<=m){now[cnt+1]=w[u];dfs(u+1,cnt+1);now[cnt+1]-=w[u];}
}
int main()
{IO;int T=1;cin>>T;while(T--){cin>>n>>m>>W;for(int i=1;i<=n;i++) cin>>w[i];sort(w+1,w+1+n);reverse(w+1,w+1+n);ok=0;memset(now,0,sizeof now);dfs(1,0);if(ok) cout<<"Yes\n";else cout<<"No\n";}return 0;}

D - 回文串

学了一下manacher算法,模板++
用manacher算法求后p[i]-1即表示原字符串回文序列长度,而且经过对字符串进行添加*操作后最终每个回文字符串的最左或右端一定是*
对于本题需求不相交且长度和最大的非空回文子串,我们可以尝试枚举划分点,左边最长的回文子串+右边最长的回文子串(预处理前缀后缀即可)即可求出。

注意:由于每个回文字符串的最左或右端一定是*,一定不会出现相交的情况。
非空想想不难知道只有在整个字符串都是回文串的情况下非空才会和不非空的结果不一样(其他情况非空的结果一定更优)。我们需要特判整个字符串是回文串的情况。

#include<cstdio>
#include<cstring>
#include<iostream>
#include<algorithm>
using namespace std;
const int N=400010;
int n;
char s[N];
int p[N],lmax[N],rmax[N];
int init()
{n=strlen(s+1);for(int i=2*n;i;i-=2){s[i]=s[i/2];s[i-1]='*';}s[2*n+1]='*';s[0]='@',s[2*n+2]='&';//哨兵return 2*n+1;
}
int manacher()
{int res=0;int now=0,mx=0;for(int i=1;i<=n;i++){p[i]=i<mx?min(p[2*now-i],mx-i):1;while(s[i+p[i]]==s[i-p[i]]) p[i]++;if(i+p[i]>mx){mx=i+p[i];now=i;}res=max(res,p[i]-1);}return res;
}
int main()
{cin>>s+1;n=init();manacher();for(int i=1;i<=n;i++){int r=p[i]+i-1;rmax[r]=max(rmax[r],p[i]-1);}for(int i=n;i;i--){int l=i-p[i]+1;lmax[l]=max(lmax[l],p[i]-1);}for(int i=1;i<=n;i++) rmax[i]=max(rmax[i-1],rmax[i]);for(int i=n;i>=1;i--) lmax[i]=max(lmax[i+1],lmax[i]);int res=0;int ok=0;// 特判整个字符串都是回文串for(int i=1;i<=n;i++) if(p[i]-1==(n-1)/2) ok=1;if(ok) cout<<(n-1)/2-1<<'\n';else {for(int i=1;i<=n;i++) res=max(res,lmax[i]+rmax[i]);cout<<res<<'\n';}return 0;    
}

E - 划分树

大佬题解
在这里插入图片描述

#define IO ios::sync_with_stdio(false);cin.tie();cout.tie(0)
#pragma GCC optimize(2)
#include<cstring>
#include<iostream>
#include<algorithm>
using namespace std;
typedef long long ll;
typedef pair<int,int> pii;
const int N=500010;
const ll mod=1004535809;
int h[N],e[2*N],ne[2*N],idx;
int n,m;
ll w[N];
ll f[N][2];
void add(int a,int b)
{e[idx]=b;ne[idx]=h[a];h[a]=idx++;
}
void dfs(int u)
{f[u][0]=1;//删除偶数条边(不删)方案数是1ll cnt1,cnt0;for(int i=h[u];i!=-1;i=ne[i]){int j=e[i];dfs(j);w[u]^=w[j];cnt0=f[u][0],cnt1=f[u][1];f[u][0]=(cnt0*f[j][0]+cnt1*f[j][1])%mod;f[u][1]=(cnt1*f[j][0]+cnt0*f[j][1])%mod;}cnt0=f[u][0],cnt1=f[u][1];if(u==1) return;// 考虑连向父亲if(w[u]==0) f[u][0]=(f[u][0]+cnt1)%mod;if(w[u]==m) f[u][1]=(f[u][1]+cnt0)%mod;}
int main()
{IO;int T=1;//cin>>T;while(T--){cin>>n>>m;memset(h,-1,sizeof h);for(int i=2;i<=n;i++){int p;cin>>p;add(p,i);}for(int i=1;i<=n;i++) cin>>w[i];dfs(1);cout<<(f[1][0]*(w[1]==m)+f[1][1]*(w[1]==0))%mod<<'\n';}return 0;}

F有点懵,先记下来。
要加油哦~

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

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

相关文章

1148 Werewolf - Simple Version 甲级

题意&#xff1a; 有n个玩家&#xff0c;有两个狼人&#xff0c;有两人说慌&#xff08;其中一个为狼人一个为非狼人&#xff09;&#xff0c;找出狼人是谁&#xff1f; 题解&#xff1a; 暴力枚举 先枚举i和j为狼人&#xff0c;然后从1号开始假设其说谎&#xff0c;然后判断…

asp.net core 错误定位 vs2017 远程调试部署在centos上的asp.net core程序

前言程序运行中会出现各种BUG。 排除BUG有三种方式。一、访问页面直接报错误信息出于安全&#xff0c;服务器是关闭这个功能的。在centos上可以用 命令设置环境变量来解决&#xff1a; export ASPNETCORE_ENVIRONMENTDevelopment二、console输出console.WriteLine(" hel…

P4585-[FJOI2015]火星商店问题【线段树,可持久化Trie】

正题 题目链接:https://www.luogu.com.cn/problem/P4585 题目大意 nnn个集合&#xff0c;开始每个集合中有一个数字。 开启新的一天并且往集合sss中插入数字vvv询问ddd天以内插入的数字&#xff08;包括最开始的&#xff09;中l∼rl\sim rl∼r集合内的数字异或上xxx的最大值。…

【图论】Tree之最小方差树(bzoj 3754)

正题 bzoj 3754 题目大意 求最小方差生成树 解题思路 可以枚举数值之和&#xff0c;然后跑最小生成树 每次加25&#xff0c;这样可以提高速度&#xff0c;且如果平均数接近&#xff0c;那么所选的边和答案会相同&#xff0c;再暴力跑一遍即可 code #include<cmath> …

1147 Heaps

题意&#xff1a; 给一个二叉树的层次遍历&#xff0c;问是什么类型的堆&#xff0c;是大顶堆还是小顶堆&#xff0c;然后输出这个树的后续遍历 题解&#xff1a; 大小堆根直接比较a[i]与a[i/2]即可 因为给的树的层次遍历&#xff0c;i就是i/2儿子 后序遍历&#xff0c;对于…

AspNet Core下利用 app-metrics+Grafana + InfluxDB实现高大上的性能监控界面

在日常系统工作中&#xff0c;我们为了洞察系统的问题和运作情况通常会记录日志的方式来进行分析&#xff0c;但是在很多情况下都是被动的在出问题后才会去查日志。在很多时候&#xff0c;我们可能更需要相对实时的了解整个系统或者某一时段的运行的情况&#xff0c;诸如系统出…

ACL Beginner Contest 总结——F多项式待补

A - Repeat ACL 签到题1 #define IO ios::sync_with_stdio(false);cin.tie();cout.tie(0) #pragma GCC optimize(2) #include<string> #include<cstring> #include<iostream> #include<algorithm> using namespace std; typedef long long ll; typed…

P5319-[BJOI2019]奥术神杖【0/1分数规划,AC自动机,dp】

正题 题目链接:https://www.luogu.com.cn/problem/P5319 题目大意 一个长度为nnn的串TTT&#xff0c;用0∼90\sim 90∼9填充所有的...。 然后给出mmm个串和它们的价值。 一个填充方案的价值等于&#xff1a;若TTT中出现了ccc个给出的串&#xff0c;那价值等于它们的价值乘积…

微软向Linux表白: 向Linux社区开放60000多项专利

10 月 10 日&#xff0c;微软在博客中宣布正式加入开放创新网络&#xff08;Open Invention Network, 简称“OIN”&#xff09;&#xff0c;向所有开源专利联盟的成员开放其专利组合。对开源&#xff0c;微软是认真的OIN 的首席执行官 Keith Bergelt 在采访中说道&#xff1a;微…

【线段树】扇形面积并(P3997)

正题 P3997 题目大意 给若干扇形&#xff0c;问你叠了至少k次的面积 解题思路 把园展开&#xff0c;然后用线段树维护每个点的出现次数 当最大次数大于k&#xff0c;用log的时间查找该点&#xff0c;然后计算结果&#xff0c;因为最多只有2*n次查找&#xff0c;所以不会TLE…

Codeforces Round #675 (Div. 2)——F主席树待补?

A - Fence 把凑得那条边当成最长的边&#xff0c;如果abcd那么将会共线&#xff0c;只要稍微abc大一点即可满足四边形。 #define IO ios::sync_with_stdio(false);cin.tie();cout.tie(0) #pragma GCC optimize(2) #include<set> #include<map> #include<cmath…

牛客网dp专题 数位dp

文章目录数位dp例题&#xff1a;NC116652 uva11038 How many 0sNC15035 送分了QAQNC20669 诡异数字NC20665 7的意志NC17385 Beautiful NumbersCF55D NC108918 Beautiful numbers习题&#xff1a;NC17867 明七暗七NC19327 好朋友NC19945 [CQOI2016]手机号码NC20268 [SCOI2009]WI…

YbtOJ#463-序列划分【二分答案,线段树,dp】

正题 题目链接:https://www.ybtoj.com.cn/problem/463 题目大意 给出长度为nnn的序列A,BA,BA,B。要求划分成若干段满足 对于任何i<ji<ji<j&#xff0c;若iii和jjj不是同一段的&#xff0c;要求满足Bi>AjB_i>A_jBi​>Aj​每一段AiA_iAi​的最大值的和不能超…

微软技术大会预览:DevOps顾问是怎样开发自己的产品的

“没有人比我们更懂DevOps”&#xff0c;这句话不是谁都敢说的。从无人问津到整个IT行业趋之若鹜&#xff0c;DevOps火起来也不过是3年的事情&#xff0c;但是leansoftX.com的DevOps资深顾问都是在这个行业已经摸爬滚打了10年的老兵了&#xff0c;从一开始的SDLC&#xff0c;到…

【双指针】Square Pasture G(P7153)

正题 P7153 题目大意 给你平面上的若干点&#xff0c;让你画一个正方形&#xff0c;问框住的点有多少种组合 解题思路 先枚举正方形左右两边的点&#xff0c;然后用双指针计算正方形移动过程中1框住的点 然后把所有点x,y坐标取反&#xff0c;再做一次&#xff0c;这样可以把…

Neat Tree

Neat Tree 题意&#xff1a; n个数&#xff0c;每个区间的贡献为区间内最大值减最小值&#xff0c;问这个n个数的总贡献是多少&#xff1f;也就是n所能组成的所有区间的贡献值之和 题解&#xff1a; 我们可以用单调栈来做 第i个数对答案的贡献值为h[i] * 作为最大值出现的次…

PEACHPIE 0.9.11 版本发布,可以上生产了

PeachPie在官方博客&#xff08;https://www.peachpie.io/2018/10/release-0911-visual-studio.html&#xff09;发布了PeachPie的0.9.11版本 - 用于.NET和.NET Core的PHP编译器和运行时。此更新为项目管理引入了许多新功能&#xff0c;兼容性增强和改进。0.9.11是第一个非预览…

YbtOJ#573-后缀表达【二分图匹配】

正题 题目链接:https://www.ybtoj.com.cn/contest/115/problem/2 题目大意 给出一个包含字母变量和若干种同级操作符的后缀表达式。求一个等价的表达式满足该表达式的连续相同段最少。 1≤∣S∣≤25001\leq |S|\leq 25001≤∣S∣≤2500 解题思路 构建出表达树先&#xff0c;…

【DP】Sleeping Cows P(P7154)

正题 P7154 题目大意 有n头牛和n个牛棚&#xff0c;每头牛可以进入体积大于等于该牛的牛棚&#xff0c;当一个所有未进入牛棚的牛都不能再进时&#xff0c;称为极大的匹配&#xff0c;问你有多少种极大的匹配 解题思路 先把牛棚和牛放到一起&#xff0c;然后按体积排序 那么…

[ZJOI2007]棋盘制作

文章目录[ZJOI2007]棋盘制作题意&#xff1a;题解&#xff1a;单调栈代码&#xff1a;悬线法[ZJOI2007]棋盘制作 题意&#xff1a; 选取最大的01相邻的正方形和矩形&#xff0c;输出面积 题解&#xff1a; 单调栈 如图&#xff1a; 左图为题目给的样例&#xff0c;我们要找…