HDU 5811 Colosseo(拓扑排序+单调DP)
【题目链接】 http://acm.hdu.edu.cn/showproblem.php?pid=5811
【题目大意】
给出 一张单向图,现在将其划分成了两个部分,问划分之后的点是否分别满足按照一定序列排序后后面的点可以直接与前面的点相连,如果可以,从第二部分拆出几个点到第一部分仍然满足这个性质。
【题解】
对于第一问,我们可以拓扑排序判断,对于第二问,我们发现先在第一组的序列中找到第二组每个点的可插入位置,在第二组的位置序列中做最长不下降子序列就是答案。
【代码】
#include <cstdio>
#include <vector>
#include <queue>
#include <climits>
#include <algorithm>
using namespace std;
const int N=1005,M=40000000;
int n,m,mark[N],d[N],map[N][N],x,f[N][N],dp[N];
vector<int> T1,T2;
char file[M],*F=file;
void read(int&x){for(x=0;*F<48;F++);while(*F>47)x=x*10+*F++-48;}
bool Topological(int t,vector<int>&ret){
vector<int> v;
for(int i=0;i<n;i++){d[i]=0;if(mark[i]==t)v.push_back(i);}
for(int i=0;i<v.size();i++){
for(int j=0;j<v.size();j++){
if(map[v[i]][v[j]])d[v[i]]++;
}
}queue<int>Q;
for(int i=0;i<v.size();i++)if(!d[v[i]])Q.push(v[i]);
while(!Q.empty()){
int u=Q.front();Q.pop();
ret.push_back(u);
for(int i=0;i<v.size();i++){
if(map[v[i]][u]){
--d[v[i]];
if(!d[v[i]])Q.push(v[i]);
}
}
}if(ret.size()!=v.size())return 0;
return reverse(ret.begin(),ret.end()),1;
}
int main(){
fread(file,1,M,stdin);
while(1){
read(n);read(m);
if(m+n==0)return 0;
for(int i=0;i<n;i++)for(int j=0;j<n;j++)read(map[i][j]);
for(int i=0;i<n;i++)mark[i]=0;
for(int i=0;i<m;read(x),mark[--x]=1,i++);
T1.clear(); T2.clear();
if(!Topological(1,T1)||!Topological(0,T2)){
puts("NO");continue;
}int ans=0;
for(int i=0;i<T2.size();i++)f[m][i]=0;
for(int i=m-1;i>=0;i--){
for(int j=0;j<T2.size();j++)f[i][j]=f[i+1][j];
for(int j=0;j<T2.size();j++){
if(map[T1[i]][T2[j]])f[i][j]=1;
}
}
for(int i=0;i<T2.size();i++){
dp[i]=INT_MIN; int t=m;
for(int j=0;j<T1.size();j++){
if(map[T2[i]][T1[j]]){t=j;break;}
}if(f[t][i])continue;
dp[i]=1;
for(int j=0;j<i;j++){
if(!f[t][j])dp[i]=max(dp[i],dp[j]+1);
}ans=max(ans,dp[i]);
}printf("YES %d\n",ans);
}return 0;
}
HDU 5811 Colosseo(拓扑排序+单调DP)的更多相关文章
- HDU.2647 Reward(拓扑排序 TopSort)
HDU.2647 Reward(拓扑排序 TopSort) 题意分析 裸的拓扑排序 详解请移步 算法学习 拓扑排序(TopSort) 这道题有一点变化是要求计算最后的金钱数.最少金钱值是888,最少的 ...
- [JZOJ 5905] [NOIP2018模拟10.15] 黑暗之魂(darksoul) 解题报告 (拓扑排序+单调队列+无向图基环树)
题目链接: http://172.16.0.132/senior/#main/show/5905 题目: oi_juruo热爱一款名叫黑暗之魂的游戏.在这个游戏中玩家要操纵一名有 点生命值的无火的余灰 ...
- ACM: hdu 2647 Reward -拓扑排序
hdu 2647 Reward Time Limit:1000MS Memory Limit:32768KB 64bit IO Format:%I64d & %I64u Des ...
- HDU 2647 Reward (拓扑排序)
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=2647 题意是给你n点m条有向边,叶子点(出度为0)上的值为888,父亲点为888+1,依次计算... ...
- hdu 5438 Ponds 拓扑排序
Ponds Time Limit: 1 Sec Memory Limit: 256 MB 题目连接 http://acm.hdu.edu.cn/contests/contest_showproblem ...
- HDU 5811 Colosseo
首先判断一下两个集合是否能够拓扑排序,顺便记录下每个节点的拓扑序. 然后看T2中每个点在T1中能够放在哪一个位置,记录下这个位置Pi. 然后T2中(按拓扑序排好),计算Pi的一个非严格递增的LIS.L ...
- CF-721C DAG图拓扑排序+费用DP
比赛的时候写了个记忆化搜索,超时了. 后来学习了一下,这种题目应该用拓扑排序+DP来做. dp[][]保存走到[第i个节点][走过j个点]时所用的最短时间. pre[][]用前驱节点求路径 然后遍历一 ...
- 2017 ACM-ICPC 亚洲区(乌鲁木齐赛区)网络赛 H. Skiing (拓扑排序+假dp)
题目链接:https://nanti.jisuanke.com/t/16957 题目: In this winter holiday, Bob has a plan for skiing at the ...
- 拓扑排序+数学+DP【洛谷P1685】 游览
P1685 游览 题目描述 顺利通过了黄药师的考验,下面就可以尽情游览桃花岛了! 你要从桃花岛的西头开始一直玩到东头,然后在东头的码头离开.可是当你游玩了一次后,发现桃花岛的景色实在是非常的美丽!!! ...
随机推荐
- php实现多表(四表)连接
<?php include_once "DBHelper.php"; define('HOST', '127.0.0.1'); define('USER', 'root'); ...
- wamp出现You don’t have permission to access/on this server提示(转)
转自http://blog.csdn.net/hong0220/article/details/40262729 ,转载方便以后查看. 今天搭建wamp集成环境,本来已经搭建好了,但是在访问local ...
- [linux]segvcatch简单使用
https://code.google.com/p/segvcatch/ This is a crossplatform C++ library designed to convert a hardw ...
- Android01-概述
1.Android特点 开源和免费 强大的研发力量,完整的生态圈 互联网服务的支持 2.Android系统架构 应用层 应用框架层 系统运行库层 Linux内 ...
- 如何修改被编译后DLL文件
原文 http://www.cnblogs.com/wujy/p/3275855.html 我们平时在工作中经常会遇到一些已经被编译后的DLL,而且更加麻烦是没有源代码可以进行修改,只能针对这个DLL ...
- H面试程序(29):求最大递增数
要求:求最大递增数 如:1231123451 输出12345 #include<stdio.h> #include<assert.h> void find(char *s) { ...
- Ubuntu 12.04下安装ibus中文输入法
这是最完整的安装方法: ibu是一个框架,可以支持多种输入法,像是pinyin,五笔等. 1,安装ibus框架 终端输入以下命令: sudo apt-get install ibus ibus-clu ...
- Python学习笔记3-文件的简单操作
Python中的文件操作 Python中文件打操作离不开两个模块 os 和 shutil os:操作文件.目录: Python os模块包含普遍的操作系统功能.如果你希望你的程序能够与平台无关的话, ...
- stdin、stdout、stderr
1 ferror 2 stdin 3 stdout 4 stderr 1 ferror 功能:检测文件是否出现错误 返值:未出错0,出错非0 说明:每次调用文件输入输出函数,均产生一个新的ferror ...
- 网易云课堂_程序设计入门-C语言_第六章:数组_2鞍点
2 鞍点(5分) 题目内容: 给定一个n*n矩阵A.矩阵A的鞍点是一个位置(i,j),在该位置上的元素是第i行上的最大数,第j列上的最小数.一个矩阵A也可能没有鞍点. 你的任务是找出A的鞍点. 输入格 ...