博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Gym - 101480K_K - Kernel Knights (DFS)
阅读量:6326 次
发布时间:2019-06-22

本文共 1358 字,大约阅读时间需要 4 分钟。

1494602-20181011114040362-1278166466.png

题意:有两队骑士各n人,每位骑士会挑战对方队伍的某一个位骑士. (可能相同)

要求找以一个区间s:
集合S中的骑士不会互相挑战.
每个集合外的骑士必定会被集合S内的某个骑士挑战.

题解:讲真被题目绕懵比了,一直不知道题目在要求找啥。

骑士可以分为三类:必定在s中,必定不再s中,不确定的。
如果一个骑士的被挑战人数为0的话,那么他一定在s中。(否则就违背了2)
如果一个骑士挑战了确定在s内的骑士,那么他一定在圈外。
若某个骑士i被多个人挑战,那么要先对这些挑战者逐一进行上述判断,若某个挑战者被确定在S外,那么说明能使骑士i满足条件2的挑战者少了一个(等同于少了一个挑战者). 若所有挑战者都在S外,那么i一定在S内。

最后会有一种情况,就是该骑士跟挑战者都不能确定在圈外还是圈内,如样例的1、5,这时候让他们任意一人在圈内就可以了。

#include 
#include
#include
#include
#include
#include
using namespace std;const int maxn = 200050;int ans[maxn],f[maxn],head[maxn],vis[maxn];void dfs(int x){ vis[x] = 1; if(vis[head[x]]==1) return; if(f[x]==1) { f[head[x]] = -1; dfs(head[x]); return; } ans[head[x]] --; if(!ans[head[x]]) { f[head[x]] = 1; dfs(head[x]); return; }}int main(){ int n,i,x,ff; cin>>n; memset(ans,0,sizeof(ans)); memset(f,0,sizeof(ans)); memset(head,0,sizeof(ans)); memset(vis,0,sizeof(ans)); for(i=1;i<=2*n;i++) { scanf("%d",&x); ans[x] ++; head[i] = x; } for(i=1;i<=2*n;i++) if(!ans[i]&&!vis[i]) { f[i] = 1; dfs(i); } ff = 0; for(i=1;i<=2*n;i++) { if(f[i]==-1) continue; if(f[i]==1) { if(!ff) { printf("%d",i); ff = 1; } else printf(" %d",i); continue; } if(i<=n) { if(!ff) { printf("%d",i); ff = 1; } else printf(" %d",i); } } printf("\n"); return 0;}

转载于:https://www.cnblogs.com/luoxiaoyi/p/9771645.html

你可能感兴趣的文章
javacsript Numnber 对象
查看>>
MOS管基本构造和工作原理
查看>>
RocketMQ原理解析-Broker
查看>>
【转】【Linux】linux下xargs命令
查看>>
sql server<> != 从数据类型varchar转换为numeric 时出错
查看>>
利用命令行发邮件
查看>>
mac install brew
查看>>
hdu1285 确定比赛名次(拓扑排序多种方法)
查看>>
mysql在linux下的安装
查看>>
php删除数组中指定值的元素
查看>>
第六天-request response\13-request乱码.avi;
查看>>
git版本超前了N个版本且落后了N个版本的解决办法
查看>>
QSettings读写注冊表、配置文件
查看>>
Elasticsearch之CURL命令的mget查询
查看>>
使用ssh-keygen生成ssh公钥和私钥
查看>>
【Centos】【Python】【Flask】阿里云上部署一个 flask 项目
查看>>
【Tomcat】详解tomcat的连接数与线程池
查看>>
TensorFlow.js之根据数据拟合曲线
查看>>
java Map常用方法封装
查看>>
matlab练习程序(纹理合成)
查看>>