L3-015. 球队“食物链”
某国的足球联赛中有N支参赛球队,编号从1至N。联赛采用主客场双循环赛制,参赛球队两两之间在双方主场各赛一场。
联赛战罢,结果已经尘埃落定。此时,联赛主席突发奇想,希望从中找出一条包含所有球队的“食物链”,来说明联赛的精彩程度。“食物链”为一个1至N的排列{ T1 T2 ... TN },满足:球队T1战胜过球队T2,球队T2战胜过球队T3,……,球队T(N-1)战胜过球队TN,球队TN战胜过球队T1。
现在主席请你从联赛结果中找出“食物链”。若存在多条“食物链”,请找出字典序最小的。
注:排列{ a1 a2 ...aN }在字典序上小于排列{ b1 b2 ... bN },当且仅当存在整数K(1 <= K <= N),满足:aK < bK且对于任意小于K的正整数i,ai=bi。
输入格式:
输入第一行给出一个整数N(2 <= N <= 20),为参赛球队数。随后N行,每行N个字符,给出了NxN的联赛结果表,其中第i行第j列的字符为球队i在主场对阵球队j的比赛结果:“W”表示球队i战胜球队j,“L”表示球队i负于球队j,“D”表示两队打平,“-”表示无效(当i=j时)。输入中无多余空格。
输出格式:
按题目要求找到“食物链”T1 T2 ... TN,将这N个数依次输出在一行上,数字间以1个空格分隔,行的首尾不得有多余空格。若不存在“食物链”,输出“No Solution”。
输入样例1:
5
-LWDW
W-LDW
WW-LW
DWW-W
DDLW-
输出样例1:
1 3 5 4 2
输入样例2:
5
-WDDW
D-DWL
DD-DW
DDW-D
DDDD-
输出样例2:
No Solution
八分的测试点总是超时,然后就改成邻接表,还是超时,学习了别人的方法,dfs到一个位置,可以查看如果剩下没访问的点都没有赢过第一个点的话,就返回,因为继续dfs下去没意义。
代码:
#include <iostream>
#include <cstdio>
#include <cstring>
#include <cstdlib>
using namespace std;
char s[];
int ss[];
int n,visited[];
int u[],v[],fir[],nex[],c,mp[][];
int flag;
int print()
{
printf("%d",ss[]);
for(int i = ;i < n;i ++)
{
printf(" %d",ss[i]);
}
}
void dfs(int k,int t)
{
if(flag)return;
if(t == n)
{
if(mp[ss[n - ]][ss[]])
{
flag = ;
print();
}
return;
}
int c = ;
for(int i = ;i <= n;i ++)
{
if(!visited[i] && mp[i][ss[]])c ++;
}
if(!c)return;
int a = fir[k];
while(a != -)
{
if(flag)return;
if(!visited[v[a]])
{
visited[v[a]] = ;
ss[t] = v[a];
dfs(v[a],t + );
visited[v[a]] = ;
}
a = nex[a];
}
}
int main()
{
scanf("%d",&n);
memset(fir,-,sizeof(fir));
for(int i = ;i < n;i ++)
{
scanf("%s",s);
for(int j = n - ;j >= ;j --)
{
if(s[j] == 'W')
{
mp[i + ][j + ] = ;
}
else if(s[j] == 'L')
{
mp[j + ][i + ] = ;
}
}
}
for(int i = ;i <= n;i ++)
{
for(int j = n;j >= ;j --)
{
if(mp[i][j])
{
u[c] = i;
v[c] = j;
nex[c] = fir[u[c]];
fir[u[c]] = c ++;
}
}
}
for(int i = ;i <= n;i ++)
{
if(!flag)
{
ss[] = i;
visited[i] = ;
dfs(i,);
visited[i] = ;
}
else break;
}
if(!flag)puts("No Solution");
}
思维要灵活,得会剪枝。。
代码:
#include <iostream>
#include <cstdio>
#include <cstring>
#include <vector>
#include <map>
#include <algorithm>
#define inf 0x3f3f3f3f
using namespace std;
char s[][];
bool vis[],al[];
int n,all;
vector<int> ans,tans;
vector<int> Next[];
void dfs(int k) {
if(!ans.empty() || tans.size() < n && all == ) return;
if(tans.size() == n) {
if(s[k][] == 'W' || s[][k] == 'L') {
ans = tans;
}
return;
}
for(int i = ;i < Next[k].size();i ++) {
if(!ans.empty()) return;
if(!vis[Next[k][i]]) {
tans.push_back(Next[k][i]);
all -= al[Next[k][i]];
vis[Next[k][i]] = ;
dfs(Next[k][i]);
vis[Next[k][i]] = ;
all += al[Next[k][i]];
tans.pop_back();
}
}
}
int main() {
scanf("%d",&n);
int flag = ;
for(int i = ;i <= n;i ++) {
scanf("%s",s[i] + );
for(int j = ;j <= n;j ++) {
if(s[i][j] == 'W') {
Next[i].push_back(j);
}
else if(s[i][j] == 'L') {
Next[j].push_back(i);
}
}
}
for(int i = ;i <= n;i ++) {
if(s[i][] == 'W' || s[][i] == 'L') {
all ++;
al[i] = true;
}
if(Next[i].empty()) flag = ;
sort(Next[i].begin(),Next[i].end());
}
tans.push_back();
vis[] = ;
if(flag) dfs();
if(ans.empty()) {
printf("No Solution");
}
else {
for(int i = ;i < n;i ++) {
if(i) putchar(' ');
printf("%d",ans[i]);
}
}
}
L3-015. 球队“食物链”的更多相关文章
- L3-015 球队“食物链” (30 分)
		L3-015 球队“食物链” (30 分) 某国的足球联赛中有N支参赛球队,编号从1至N.联赛采用主客场双循环赛制,参赛球队两两之间在双方主场各赛一场. 联赛战罢,结果已经尘埃落定.此时,联赛主席 ... 
- L3-015. 球队“食物链”(dfs)
		L3-015. 球队“食物链” 某国的足球联赛中有N支参赛球队,编号从1至N.联赛采用主客场双循环赛制,参赛球队两两之间在双方主场各赛一场. 联赛战罢,结果已经尘埃落定.此时,联赛主席突发奇想,希望从 ... 
- pat 团体天梯赛 L3-015. 球队“食物链”
		L3-015. 球队“食物链” 时间限制 1000 ms 内存限制 262144 kB 代码长度限制 8000 B 判题程序 Standard 作者 李文新(北京大学) 某国的足球联赛中有N支参赛球队 ... 
- PAT L3-015. 球队“食物链”
		L3-015. 球队“食物链” 时间限制 1000 ms 内存限制 262144 kB 代码长度限制 8000 B 判题程序 Standard 作者 李文新(北京大学) 某国的足球联赛中有N支参赛球队 ... 
- 【搜索-剪枝-偏难】PAT-天梯赛-L3-015. 球队“食物链”
		L3-015. 球队“食物链” 某国的足球联赛中有N支参赛球队,编号从1至N.联赛采用主客场双循环赛制,参赛球队两两之间在双方主场各赛一场. 联赛战罢,结果已经尘埃落定.此时,联赛主席突发奇想,希望从 ... 
- L3-015. 球队“食物链”【DFS + 剪枝】
		L3-015. 球队"食物链" 时间限制 1000 ms 内存限制 262144 kB 代码长度限制 8000 B 判题程序 Standard 作者 李文新(北京大学) 某国的足球 ... 
- 球队“食物链”(DFS+剪枝)
		某国的足球联赛中有N支参赛球队,编号从1至N.联赛采用主客场双循环赛制,参赛球队两两之间在双方主场各赛一场. 联赛战罢,结果已经尘埃落定.此时,联赛主席突发奇想,希望从中找出一条包含所有球队的“食物链 ... 
- CCCC L3-015. 球队“食物链”(dfs+剪枝)
		题意: 某国的足球联赛中有N支参赛球队,编号从1至N.联赛采用主客场双循环赛制,参赛球队两两之间在双方主场各赛一场. 联赛战罢,结果已经尘埃落定.此时,联赛主席突发奇想,希望从中找出一条包含所有球队的 ... 
- PAT 天梯赛 【】 L3-015. 球队“食物链” 【BFS+剪枝】
		题目链接 https://www.patest.cn/contests/gplt/L3-015 思路 用一个 数组标记 胜负 每次输入一行字符串 然后遍历 如果 碰到 W 那么 vis[i][j] = ... 
随机推荐
- JavaScript apply
			https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Function/apply The ... 
- leetcode-easy-array-1 two sum
			mycode 33.91% class Solution: def twoSum(self, nums: List[int], target: int) -> List[int]: for i ... 
- 各种sort排序总结
			冒泡排序 选择排序 插入排序 
- 阶段3 1.Mybatis_04.自定义Mybatis框架基于注解开发_2 回顾自定义mybatis的流程分析
- 在VSCode中开启ESLint风格审查
			最近一直在学习开发一个VUE项目,几乎没有前端基础摸爬滚打,就一边摸索HTML,JS,CSS一边模仿着已有代码开发,也还算能学到东西. VSCode确实还不错,很轻量.在刚开始学写vue的时候,后台总 ... 
- case when then else end 累加
			表结构 id(pk) satisfy(满意,一般,不满意) 一条语句查询 总数 各satisfy总数 SELECT count(*) AS 总数, count( CASE satisfy WHEN ' ... 
- MariaDB增删改
			1.MariaDB 数据类型 MariaDB数据类型可以分为数字,日期和时间以及字符串值. 使用数据类型的原则:够用就行, 尽量使用范围小的,而不用大的 常用的数据类型: 1.整数:int, bit( ... 
- RabbitMQ使用(上)
			1. 说明 在企业应用系统领域,会面对不同系统之间的通信.集成与整合,尤其当面临异构系统时,这种分布式的调用与通信变得越发重要.其次,系统中一般会有很多对实时性要求不高的但是执行起来比较较耗时的地方, ... 
- Vue模版编译
			一 模版文件 <div> <header> <h1>I'm a template!</h1> </header> <p v-if=&q ... 
- Canvas入门07- 自定义实现虚线的绘制
			预备知识 直线的斜率 一条直线与某平面直角坐标系x轴正半轴方向的夹角的正切值即该直线相对于该坐标系的斜率. 对于一条直线 y = kx +b,k就是直线的斜率. 斜率的计算 对于一条已知的线段,求斜率 ... 
