当前位置: 代码迷 >> 综合 >> CF1569B Chess Tournament
  详细解决方案

CF1569B Chess Tournament

热度:33   发布时间:2023-10-14 00:22:56.0

原题链接

题意

CF1569B Chess Tournament

思路

通过举例子发现,至少赢一次的人数小于等于2同时不等于0时,是NO,
还有的至少赢一次的就赢一次,赢另一个至少赢一次的人,剩余的全部都平局即可。

代码

#include<bits/stdc++.h>
using namespace std;
const int N = 100;
int ans[N][N];
int main()
{
    int t;cin >> t;while (t -- ){
    memset(ans, -1, sizeof ans);string s;int n;cin >> n;cin >> s;int a = 0, b = 0;for (int i = 0; i < s.length(); i ++ ){
    if (s[i] == '1') a ++;if (s[i] == '2') b ++;} if (b <= 2 && b != 0) {
    cout << "NO" << endl;continue;}for (int i = 1; i <= n; i ++ ){
    for (int j = i + 1; j <= n; j ++ ){
    ans[i][j] = 2; //平局 ans[j][i] = 2; //}}for (int i = 1; i <= n; i ++ ) {
    if (s[i - 1] == '2'){
    for (int j = 1; j <= n; j ++ ){
    if (i != j && s[j - 1] == '2' && ans[i][j] == 2){
    ans[i][j] = 1;ans[j][i] = 0;break;}}}}cout << "YES" << endl;for (int i = 1; i <= n; i ++ ){
    for (int j = 1; j <= n; j ++ ){
    if (ans[i][j] == 2) cout << "=";if (ans[i][j] == 1) cout << "+";if (ans[i][j] == -1) cout << "X";if (ans[i][j] == 0) cout << "-";}cout << endl;}}return 0;
}

总结

CF1569B Chess Tournament
这道题写了差不多有40min,还是要多加练习