牛客练习赛 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,一经查实,立即删除!

相关文章

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

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

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

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

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

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

牛客网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…

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

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

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是第一个非预览…

[ZJOI2007]棋盘制作

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

.net core实践系列之SSO-同域实现

前言SSO的系列还是以.Net Core作为实践例子与大家分享&#xff0c;SSO在Web方面复杂度分同域与跨域。本篇先分享同域的设计与实现&#xff0c;跨域将在下篇与大家分享。如有需要调试demo的&#xff0c;可把SSO项目部署为域名http://sso.cg.com/&#xff0c;Web1项目部署为http:…

【悬线法】学习总结

【悬线法】学习总结 主要用于求满足某条件的最大矩阵 定义&#xff1a; 一条竖线&#xff0c;竖线的上端点位于矩阵的上边界或是一个障碍点&#xff0c;然后对这条悬线进行左右移动&#xff0c;直到移至障碍点或者是矩阵边界&#xff0c;进行确定这条悬线所在的极大矩阵。 底…

开源硬件论坛,燃烧你的创造力

写在大会前开源融合&#xff1a;比特与原子开源硬件延伸着开源软件的理念&#xff0c;包括硬件设计文件及基于此文件的产品都使用具有开源性质的许可协议&#xff0c;自由使用分享。虽然&#xff0c;从仅开放硬件所配套软件到对硬件本身设计也进行开放的过程&#xff0c;曾经一…

牛客练习赛 55

A - 等火车 #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> #inclu…

单调栈讲解

以前一直有接触&#xff0c;但是一直没单独进行分析处理 单调栈&#xff1a;维护其中元素单调性的栈 也就是从栈底到栈顶都是有序的 维护&#xff1a;如果入栈的元素满足单调性&#xff0c;直接入栈&#xff1b;如果不满足&#xff0c;就让栈顶元素出栈&#xff0c;直到能让入栈…

【深圳(活动)】70多场干货分享!价值899元的2018中国开源年会门票等你认领

开源发展20年&#xff0c;.NET Core开源 4年时间&#xff0c;.NET开源实现Mono也有18年的时间&#xff0c;特别近年国内.NET Core社区的蓬勃发展&#xff0c;.NET Core中国社区作为中国开源社区的重要参与者&#xff0c;获得官方的优惠票. 活动主办方开源社&#xff0c;为.NET …

2019-2020 ICPC Asia Hong Kong Regional Contest 补题(部分)

codeforces原题链接 大佬题解 B - Binary Tree 每个人每次一定拿走奇数&#xff08;2k−12^k-12k−1&#xff09;个节点&#xff0c;如果先手必胜不难发现两人轮流拿最终一定拿奇数次&#xff08;每次奇数个节点&#xff09;说明一共有奇数个节点&#xff0c;如果先手必败说明…

广州 office365的开发者训练营交流活动简报

2018年10月13日&#xff0c;在 微软广州办公室&#xff08;广州市天河区太古汇1座28层微软广州办公室&#xff09; 成功举办了office365的开发者训练营&#xff0c;本活动在微软官网的地址&#xff1a; https://www.microsoft.com/china/events/detail_1707。这次活动得到微软O…

数据结构题

来源&#xff1a;牛客网&#xff1a; 题目描述 题目背景 把一张纸对折100次就和珠穆朗玛峰一样高了哦 ——syh 题目描述 注:本系列题不按难度排序哦 输入描述: 第一行一个n,m 接下来一行n个数表示a[i] 接下来m行&#xff0c;每行l,r,l1,r1,x&#xff0c;表示求get(l,r,x)…

YbtOJ#832-鸽子饲养【凸包,Floyd】

正题 题目链接:https://www.ybtoj.com.cn/contest/116/problem/3 题目大意 给出两个大小分别为n,mn,mn,m的点集A,BA,BA,B。 求出BBB的一个最小子集使得该子集的凸包包含了所有点集AAA中的点。 无解输出−1-1−1 2≤n≤105,3≤m≤5002\leq n\leq 10^5,3\leq m\leq 5002≤n≤…

声明式RESTful客户端在asp.net core中的应用

1 声明式RESTful客户端声明式服务调用的客户端&#xff0c;常见有安卓的Retrofit、SpringCloud的Feign等&#xff0c;.net有Refit和WebApiClient&#xff0c;这些客户端都是以java或.net某个语言来声明接口&#xff0c;描述如何请求RESTful api。1.1 WebApiClientWebApiClient由…

常见形式 Web API 的简单分类总结

一、请求--响应API请求--响应类的API的典型做法是&#xff0c;通过基于HTTP的Web服务器暴露一个/套接口。API定义一些端点&#xff0c;客户端发送数据的请求到这些端点&#xff0c;Web服务器处理这些请求&#xff0c;然后返回响应。响应的格式通常是JSON或XML。在这种类型的Web…

Graph Coloring I

来源&#xff1a;牛客网&#xff1a; 题目描述 修修在黑板上画了一些无向连通图&#xff0c;他发现他可以将这些图的结点用两种颜色染色&#xff0c;满足相邻点不同色。 澜澜不服气&#xff0c;在黑板上画了一个三个点的完全图。修修跟澜澜说&#xff0c;这个图我能找到一个简…