题解:P9938 [USACO21OPEN] Acowdemia II B
前言:原来的 tj 干了一堆什么建图啊之类的,但其实不要这么复杂。
注:下文中
从
但是捏,如果存在
要是
ACCode:
// Problem: P9938 [USACO21OPEN] Acowdemia II B
// Contest: Luogu
// URL: https://www.luogu.com.cn/problem/P9938
// Memory Limit: 256 MB
// Time Limit: 1000 ms
//
// Powered by CP Editor (https://cpeditor.org)
/*Code by Leo2011*/
#include <bits/stdc++.h>
#define log printf
#define EPS 1e-8
#define INF 0x3f3f3f3f
#define FOR(i, l, r) for (int(i) = (l); (i) <= (r); ++(i))
#define IOS \
ios::sync_with_stdio(false); \
cin.tie(nullptr); \
cout.tie(nullptr);
using namespace std;
typedef __int128 i128;
typedef long long ll;
typedef pair<int, int> PII;
int k, n;
string s;
map<string, int> members;
template <typename T>
inline T read() {
T sum = 0, fl = 1;
char ch = getchar();
for (; !isdigit(ch); ch = getchar())
if (ch == '-') fl = -1;
for (; isdigit(ch); ch = getchar()) sum = sum * 10 + ch - '0';
return sum * fl;
}
template <typename T>
inline void write(T x) {
if (x < 0) putchar('-'), x = -x;
static T sta[35];
int top = 0;
do { sta[top++] = x % 10, x /= 10; } while (x);
while (top) putchar(sta[--top] + 48);
}
int main() {
IOS cin >> k >> n;
FOR(i, 0, n - 1)
cin >> s, members[s] = i;
vector<vector<char>> ans(n, vector<char>(n, '?')); // 全给我干成一个值,为了方便就用'?'
FOR(i, 0, n - 1)
ans[i][i] = 'B'; // 初始化一下,后面就不用搞了
FOR(i, 0, k - 1) {
vector<string> pub(n);
FOR(j, 0, n - 1) cin >> pub[j];
FOR(j, 0, n - 1) {
bool flag = true;
FOR(l, j + 1, n - 1) {
if (pub[l - 1].compare(pub[l]) > 0) flag = false;
if (!flag) {
int a = members[pub[j]], b = members[pub[l]];
ans[a][b] = '0';
ans[b][a] = '1'; // 上面的过程
}
}
}
}
FOR(i, 0, n - 1) {
FOR(j, 0, n - 1) cout << ans[i][j];
cout << endl;
}
return 0;
}
理解万岁!
分类:
题解 / USACO
标签:
C艹
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· DeepSeek 开源周回顾「GitHub 热点速览」
· 记一次.NET内存居高不下排查解决与启示
· 物流快递公司核心技术能力-地址解析分单基础技术分享
· .NET 10首个预览版发布:重大改进与新特性概览!
· .NET10 - 预览版1新功能体验(一)