题目链接点这里codeforces1567B

题意:不久将举行国际象棋比赛,届时将有 n 位国际象棋选手参加。 每个参与者将与其他参与者进行一场比赛。 每场比赛的结果要么是一个玩家赢,另一个玩家输,要么是双方平局。每个玩家对锦标赛都有自己的期望,他们可以是以下两种类型之一:玩家不想输掉任何一场比赛(即以零损失完成比赛);玩家想要赢得至少一场比赛。您必须确定是否存在所有比赛的结果,以便所有玩家都满足他们的期望。 如果有多种可能的结果,请打印其中任何一个。 如果没有,请报告这是不可能的。

输入

第一行包含一个整数 t (``1≤t≤20`)——测试用例的数量。

每个测试用例的第一行包含一个整数 n (2≤n≤50)——棋手的数量。

第二行包含字符串 s(|s|=n; si∈{1,2})。 如果 si=1,则第 ii 个玩家有第一种类型的期望,否则为第二种类型。

输出

对于每个测试用例,按以下格式打印答案:

在第一行,如果无法满足所有玩家的期望,则打印 NO

否则,打印 YES,并在接下来的 n 行中打印大小为 n×n 的矩阵。

i 行第 j 列中的矩阵元素应等于:

+,如果第i 名玩家在与第 j 名玩家的比赛中获胜;

- 如果第 i 名玩家在与第 j 名玩家的比赛中输了;

=,如果第 i 和第 j 名玩家的比赛结果为平局;

X,如果 i=j

思路

按题目要求初始化矩阵,对角线为X,其余位置先为-

首先判断是否能完成要求,如果去除要求平局的点,右上三角形除斜边之外的其他点的数量如果不小于想至少获胜一局的人的数量,就能够完成。否则则不能完成要求。如果可以完成则搜索数字串,每一行从首位开始,如果遇到一个2,让第一个点改为+;每当改完一个点之后,让这一行之后的全为-;最后进行一次批处理。+-在对角线两侧是相互对立的。至此,我们完成了胜负表的绘制。详细代码如下:

#include<bits/stdc++.h>
using namespace std;
int t,n;
char s[60];
char a[60][60];
int cnt=0;
void init0(int n)
{for(int i=0;i<n;i++)for(int j=0;j<n;j++)a[i][j]='-';for(int i=0;i<n;i++){a[i][i]='X';}
}
void init1(int u)
{for(int i=0;i<n;i++){if(i==u||a[u][i]=='=')continue;a[u][i]='=';cnt++;}for(int i=0;i<n;i++){if(i==u||a[i][u]=='=')continue;a[i][u]='=';cnt++;}
}
int main()
{#ifndef ONLINE_JUDGEfreopen("in.txt","r",stdin);freopen("out.txt","w",stdout);#endifcin>>t;while(t--){   cnt=0;int tt=0;cin>>n>>s;init0(n);for(int i=0;i<n;i++){if(s[i]=='1'){tt++;init1(i);}}int aa;for(int i=0;i<n;i++){aa=0;for(int j=i+1;j<n;j++){if(a[i][j]=='-'&&aa==0){a[i][j]='+';aa=1;}else if(a[i][j]=='-')a[j][i]='+';}}tt=n-tt;int ans=(n*n-n)/2;cnt/=2;ans-=cnt;for(int i=0;i<n;i++){a[i][i]='X';}if(ans<tt)cout<<"NO"<<endl;else{cout<<"YES"<<endl;for(int uu=0;uu<n;uu++){for(int hh=0;hh<n;hh++)cout<<a[uu][hh];cout<<endl;}    }}
}

codeforces1567B相关推荐

最新文章

  1. F#探险之旅(三):命令式编程(上)
  2. putty/xshell/Secure CRT远程工具详解
  3. FreeRTOS初步认识
  4. Oracle优化02-锁和阻塞
  5. [initandlisten] connection refused because too many open connections: 819 of 819
  6. 多线程程序中操作的原子性
  7. Java基础学习-Path环境变量的配置
  8. git使用记录_备忘
  9. ln: 创建符号链接 “include/asm”: 不支持的操作
  10. 北京科技大学计算机专业博导,北京科技大学计算机与通信工程学院-班晓娟
  11. ASP.NET Core 2.2 : 十六.扒一扒新的Endpoint路由方案(转)
  12. 定了!华为的AI技术路线向开发者开放!
  13. C#中执行Dos命令
  14. 小程序 富文本解析方式
  15. win10下使用DuetDisplay有线/无线连接,推荐通过爱思助手(非iTunes)更新驱动
  16. 部署企业级项目管理系统(蝉道)
  17. 倒杨辉三角4行c语言,倒杨辉三角
  18. DW_axi_dmac控制器(术语)
  19. java button属性设置_java的JButton怎样设置内边距
  20. 解决pdf不能打印,不能注释,不能修改,不能保存等文档限制

热门文章

  1. python小应用之整理手机图片_手把手:扫描图片又大又不清晰?这个Python小程序帮你搞定!...
  2. linux学习计划书
  3. ZooKeeper示例 实时更新server列表
  4. 在IDEA里gradle配置和使用
  5. concat,ucase/lcase,left/right,length,replace
  6. 如何才能成为一名优秀的设计师?
  7. “销售方法”一个让大多数人撑握不正确的问题!
  8. three.js 源码注释(六十一)objects/LOD.js
  9. python要什么电脑配置_学Python需要什么配置的电脑?
  10. js判断字符串字符数(汉字算两个)