当前位置: 首页 > news >正文

题解:P7989 [USACO21DEC] Bracelet Crossings G

题解:P7989 [USACO21DEC] Bracelet Crossings G

这题代码细节有点多,我调了半天发现是数组开小了

思路

题目中的每个手链可以简单理解为一调首尾相连的线,要求没有线相交。

首先要判断有没有断开的线。

那么对于每一条线,可以判断有没有同一种颜色出现在这条线的内部和外部,这种情况是不合法的。

比如有一个垂直线上面的颜色分别是123321,则称颜色 3 在颜色 2 的内部,颜色 1 在颜色 2 的外部。

如果有一个垂直线上面的颜色分别是123231,则这是不合法的,因为颜色 3 同时出现在了颜色 2 的内部和外部。

接下来如果有某种颜色只出现在这条线的一个地方,即上方,内部,或下方,则这种颜色对于这条线来说是合法的。

如果有某种颜色只在这条线的上方和下方,就有可能是这种颜色的线包住了这条线,这时就需要特判是否全部包围,否则就是不合法的。

比如有两个垂直线上面的颜色分别是11222211,虽然颜色 1 出现在了颜色 2 的外侧,但并没有包围颜色 2,所以不合法。

具体处理过程细节很多,可以结合代码理解。

代码

#include<bits/stdc++.h>
using namespace std;
typedef long long ll;
int t,n,m;
int vis[55][55];//vis[i][j]:判断在第i条垂直线上是否有第j种颜色;
int L[55];//L[i]:表示第i条垂直线的颜色数量 
int a[55][105];//a[i][j]:表示第i条垂直线的第j种颜色 
int p[55][55][3];//p[i][j][k]:表示颜色j是否在颜色i的 上方/内部/下方(k=0/1/2) 出现过 
int pl[55][55];//pl[i][j]:表示第i条垂直线颜色j的第2个位置 
int pr[55][55];//pl[i][j]:表示第i条垂直线颜色j的第2个位置 
int main(){ios::sync_with_stdio(false);cin.tie(0);cin>>t;while(t--){memset(vis,0,sizeof(vis));memset(p,0,sizeof(p));memset(a,0,sizeof(a));memset(pl,0,sizeof(pl));memset(pr,0,sizeof(pr));cin>>n>>m;for(int i=1;i<=m;i++){cin>>L[i];for(int j=1;j<=L[i];j++){cin>>a[i][j];vis[i][a[i][j]]=1;if(!pl[i][a[i][j]])pl[i][a[i][j]]=j;else pr[i][a[i][j]]=j;}}int fl=1;//记录是否合法 for(int i=1;i<=n&&fl;i++){int l=-1/*判断颜色i出现的最左侧的垂直线*/,r=-1/*判断颜色i出现的最右侧的垂直线*/,mid=-1/*记录中间是否断开*/;for(int j=1;j<=m&&fl;j++){if(vis[j][i]){if(l==-1)l=j;else if(mid==1)fl=0;r=j;}else if(l!=-1)mid=1;}for(int j=l;j<=r&&fl;j++){int cnt=0;//当前出现了几次颜色i(便于记录) for(int k=1;k<=L[j];k++){if(a[j][k]==i)cnt++;else p[i][a[j][k]][cnt]++;}}for(int j=1;j<=n&&fl;j++)if(j!=i){if(p[i][j][0]&&p[i][j][1]||p[i][j][1]&&p[i][j][2]){//如果颜色j在颜色i的内部和外部都出现过 fl=0;break;}if(p[i][j][0]&&p[i][j][2])for(int k=l;k<=r&&fl;k++)if(pl[k][j]>pl[k][j]||pr[k][j]<pr[k][i])fl=0;//判断颜色j是否包围了颜色i }}cout<<(fl?"YES":"NO")<<'\n';}return 0;
}
http://www.dtcms.com/a/513976.html

相关文章:

  • 宁远做网站msoer在小说网站做责编
  • 有做兼职赚钱的网站吗南宁有名的seo费用
  • 做电商卖玉器的网站HTML建网站
  • 电影网站怎么做优化国内有类似wordpress
  • 如何学做网站外包天津建设工程招标网
  • 金华官方网站建设表白视频制作网站
  • 现在还有企业做网站吗常州网站支付通道建设
  • 如何用模版做网站深圳福田网站优化网络营销培训学校
  • 杭州网站建设费用多少app推广平台接单渠道
  • debian13安装PostgreSQL并远程连接
  • 做网站需要多大的内存潍坊建网站的
  • 网站建设应该考虑哪些问题汕头澄海玩具
  • 做装修的业务网站请稍后重试(3008)
  • 济南网站优化推广php网站开发总结文档
  • 用html做网站源代码东莞市国外网站建设报价
  • 网站建设交流平台如何制作自己的网站视频教程
  • 江门加盟网站建设德阳做网站
  • 网站建设商务通什么意思网站做sem推广时要注意什么意思
  • 买完域名后如何建设网站wordpress 客户端使用
  • 网站后台软件可以自己做吗全屋定制十大品牌排行榜前十名
  • phpcms网站建设做装修工程找什么网站接单
  • 高校门户网站建设本溪建设网站
  • 办公家具网站模板网站开发证书要求
  • 山东省建设厅招标网站首页网站开发的收入
  • 容桂网站制作咨询湛江h5建站
  • 深圳网站建设网网站建设 需求
  • 邢台seo网站制作如何跟进psd做网站
  • 网站专题报道页面怎么做的河南网站托管
  • 上海高端品牌网站建设专家优设网设计师导航
  • 如何免费申请网站白云网站建设公