CF#541 D. Gourmet choice /// BFS 拓扑
题目大意:
给定n m 第一行有n个数 第二行有m个数
接下来n行每行m列 有 = < >
位于 i j 的符号表示 第一行第i个数与第二行第j个数的大小关系
1.将n+m个数 当做按顺序编号的点
则第二行的数是编号为 n+j 的点
2.先处理=的数 将所有=的数指向同一个父亲
3.再处理不是=的数
找到两者的父亲
如果父亲相同说明两者= 与目前处理的情况相悖 无解
否则 按由小到大的关系在两者(的父亲)间连单向边(小连向大) 此时较大的点入度+1
4.此时查看所有点的入度
入度为0 说明这个点是所有数中最小的数
将它们的答案设为1 放进队列
5.广搜 取出队列里的点
判断是否能去向下一个点 能到的点数值比当前点大
所以 它们的答案 是 当前点的答案+1
6.查看对应点的答案 应该查询 这个点的父亲(数值相等) 的答案
因为连边时 实际上是在对应点的父亲之间连的边
#include <bits/stdc++.h>
using namespace std;
#define LL long long
#define INF 0x3f3f3f3f
#define mem(i,j) memset(i,j,sizeof(i))
#define inc(i,l,r) for(int i=l;i<=r;i++)
#define dec(i,r,l) for(int i=r;i>=l;i--)
const int N=1e3+;
const int NN=N<<;
const int mod=1e9+; int n, m;
char G[N][N];
int E[NN][NN];
int du[NN], ans[NN];
int fa[NN];
int getfa(int x) {
if(fa[x]==x) return x;
else return fa[x]=getfa(fa[x]);
}
int main()
{
while(~scanf("%d%d",&n,&m)) {
inc(i,,n) scanf("%s",G[i]+);
inc(i,,n+m) fa[i]=i;
inc(i,,n) inc(j,,m) // 第二行的编号为n+j
if(G[i][j]=='=') fa[getfa(i)]=getfa(n+j);
// 相等的连到同一个父亲
bool OK=; mem(E,); mem(du,);
inc(i,,n) inc(j,,m)
if(G[i][j]!='=') {
int fi=getfa(i), fj=getfa(n+j);
// 父亲相同说明相等 但此时是不等的情况 则无解
if(fi==fj) OK=;
else {
if(G[i][j]=='<'&&E[fi][fj]==)
E[fi][fj]=, du[fj]++;
else if(G[i][j]=='>'&&E[fj][fi]==)
E[fj][fi]=, du[fi]++;
} // 由小向大连边 并计算点的入度
}
if(OK==) { puts("No"); continue; }
queue<int>q;
inc(i,,n+m) // 入度为0说明是最小的
if(du[i]==) q.push(i), ans[i]=;
while(!q.empty()) {
int u=q.front(); q.pop();
inc(i,,n+m)
if(E[u][i] && --du[i]==) // 入度减1 即去掉u点
q.push(i), ans[i]=ans[u]+;
// 入度减为0说明没有比他更小的了
}
inc(i,,n+m) if(du[i]) OK=;
if(OK==) { puts("No"); continue; }
puts("Yes");
inc(i,,n) printf("%d ",ans[getfa(i)]); printf("\n");
inc(i,,m) printf("%d ",ans[getfa(n+i)]); printf("\n");
} return ;
}
CF#541 D. Gourmet choice /// BFS 拓扑的更多相关文章
- Codeforces #541 (Div2) - D. Gourmet choice(拓扑排序+并查集)
Problem Codeforces #541 (Div2) - D. Gourmet choice Time Limit: 2000 mSec Problem Description Input ...
- codeforces #541 D. Gourmet choice(拓扑+并查集)
Mr. Apple, a gourmet, works as editor-in-chief of a gastronomic periodical. He travels around the wo ...
- CF - 1131 D Gourmet choice
题目传送门 先把 = 的人用并查集合并在一起. 然后 < > 的建边, 跑一遍 toposort 之后就好了. 入度为0点的值肯定为1, 然后就是因为这个是按照时间线走过来的,所以一个点的 ...
- D. Gourmet choice并查集,拓扑结构
D. Gourmet choice time limit per test 2 seconds memory limit per test 256 megabytes input standard i ...
- coderfoces D. Gourmet choice
D. Gourmet choice time limit per test 2 seconds memory limit per test 256 megabytes 题目链接: https: ...
- 【CF #541 D】 Gourmet choice
link:https://codeforces.com/contest/1131 题意: 给定一些大小比较,输出排名. 思路: 这道题我用的是拓扑排序,又因为有等于号的存在,我用了并查集. 结束后这道 ...
- CF1131D Gourmet choice(并查集,拓扑排序)
这题CF给的难度是2000,但我感觉没这么高啊…… 题目链接:CF原网 题目大意:有两个正整数序列 $a,b$,长度分别为 $n,m$.给出所有 $a_i$ 和 $b_j(1\le i\le n,1\ ...
- CF #375 (Div. 2) D. bfs
1.CF #375 (Div. 2) D. Lakes in Berland 2.总结:麻烦的bfs,但其实很水.. 3.题意:n*m的陆地与水泽,水泽在边界表示连通海洋.最后要剩k个湖,总要填掉多 ...
- CF 520 B. Two Buttons(bfs)
/*题意:一个数,就是输入的第一个数,让它变成第二个数最少用几步.可以点红色按钮,蓝色按钮来改变数字,红色:*2,蓝色:-1,如果变成负数,就变成原来的数.CF 520 B. Two Buttons思 ...
随机推荐
- CMDB 调研报告
基础概念 1.什么是CMDB CMDB——配置管理数据库,通过识别.控制.维护,检查企业的IT资源,从而高效控制与管理不断变化的IT基础架构与IT服务,并为其它流程,例如事故管理.问题管理.变更管理. ...
- vue轮播,展示pdf
vue轮播,展示pdf 根据左侧图片格式,右侧展示相应的pdf文件与图片.(vue中不支持pdf格式,pdf文件要放在static文件里):代码如下: <template> <!-- ...
- Django框架(二十四)—— Django rest_framework-视图组件
目录 视图组件 一.基本视图 二.自定义的封装视图 三.利用mixin类和generice类编写视图 1.使用 2.源码 四.利用generics 下的ListCreateAPIView,Retrie ...
- DB2连接
ibm_db.connect 创建非持久连接. ibm_db.pconnect 创建持久连接. 在最初的Python脚本请求之后,持久的连接保持打开状态,这允许后续的Python请求重新使用连接. 后 ...
- flask中配置并使用mongodb
在你安装并运行了mongodb的情况下: 随便在一个文件中写入以下代码: import pymongo client = pymongo.MongoClient(host="localhos ...
- 36-python基础-python3-字典与列表的区别
(1)不像列表,字典中的表项是不排序的.名为 spam 的列表中,第一个表项是 spam[0].但字典中没有“第一个”表项. (2)确定两个列表是否相同时,表项的顺序必须相同,但在字典确定两个字典是否 ...
- springboot整合jsp 遇到的问题
1,在idea中新建jsp文件 首先需要在springboot项目 在src 中webapp /WEB-INF/JSP 当我右键想新建一个jsp文件时默认没有 File->Project Str ...
- ArcGis基础——设置图层可选状态
在ArcMap的图层列表上右键,可以设置“仅本图层可选”. 那么,如何设置回多个或者全部图层可选状态呢? 1.在ArcMap的菜单栏找到 自定义——自定义模式——选择——设置可选图层. 2.将“设置可 ...
- 5、springcloud整合mybatis注解方式
1.上一篇学习了服务提供者provider,但是并不是单单就学习了服务提供者.中间还穿插使用了Hikari数据源和spring cloud整合mybatis.但是上篇使用mybatis时还是沿用了老的 ...
- 1、eureka注册中心单机
Spring Cloud 2.x系列之 eureka注册中心单机 一.简介 Spring Cloud Eureka是Spring Cloud Netflix项目下的服务治理模块.而Spring Clo ...