首页 > 其他分享 >题解:P9938 [USACO21OPEN] Acowdemia II B

题解:P9938 [USACO21OPEN] Acowdemia II B

时间:2024-08-29 14:47:39浏览次数:10  
标签:P9938 ch int 题解 sum pub II cdots

前言:原来的 tj 干了一堆什么建图啊之类的,但其实不要这么复杂。


注:下文中 \(n\) 是各成员名字列表。

从 \(K = 1\) 开整。如果情况是 \(n_i < n_{i + 1}< \cdots < n_j\),那么显然,咱就不知道关于成员 \(n_i,\cdots,n_j\) 的相对资历的信息。也许所有这帮成员都做出了相同的贡献。

但是捏,如果存在 \(i\) 使得 \(n_i > n_{ + 1}\),则成员 \(n_i\) 肯定比成员 \(n_{i + 1}\) 干了更多的活儿,因此所有成员 \(n_1,\cdots,n_i\) 必须比成员 \(n_{i + 1} \cdots n_N\) 的贡献少。换句话说,如果 \(i < j\) 但 \(n_i, n_{i + 1},\cdots,n_j\) 不是按字母顺序排列的,那么咱就知道 \(n_i\) 肯定比 \(n_j\) 资历浅了。

要是 \(K > 1\) 捏?把信息怼起来不就得了?


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;
}

AC记录~

理解万岁!

标签:P9938,ch,int,题解,sum,pub,II,cdots
From: https://www.cnblogs.com/leo2011/p/18382249

相关文章

  • OLED显示屏详解(IIC协议0.96寸 STM32)
     目录 一、介绍 二、模块原理1.原理图2.工作原理:SSD1306显存与命令三、程序设计main.c文件oled.h文件oled.c文件四、实验效果 五、资料获取项目分享一、介绍        OLED是有机发光二极管,又称为有机电激光显示(OrganicElectroluminescenceDisplay......
  • AWTF2024A Moving Slimes 题解
    发现史莱姆不合并也不会影响答案,所以就不用考虑合并了。这样处理之后,史莱姆的移动可以看作是受到与其不在同一位置的史莱姆的吸引所完成的,每只史莱姆可以给其他史莱姆一个单位的吸引力。因为每只史莱姆提供的吸引力是恒定的,所以考虑把吸引力放在它们的重心上,设\(pre_i\)表示坐......
  • 历年CSP-J初赛真题解析 | 2016年CSP-J初赛阅读程序(23-26)
    学习C++从娃娃抓起!记录下CSP-J备考学习过程中的题目,记录每一个瞬间。附上汇总贴:历年CSP-J初赛真题解析|汇总_热爱编程的通信人的博客-CSDN博客#include<iostream>usingnamespacestd;intmain(){intmax,min,sum,count=0;inttmp;cin>>tmp;......
  • CF1286E Fedya the Potter Strikes Back 题解
    题目链接点击打开链接题目解法牛题!题目实际上是要每次加入一个字符,求所有的\(border\)的神秘度之和考虑从前\(i-1\)个字符到前\(i\)个字符\(border\)的变化如果\(str_1=str_i\),会加入长度为\(1\)的\(border\),这一部分可以暴力加且只会保留\(i-1\)的\(border......
  • 华为java岗经典面试题解析
    题目为在一个整形的数组中,在数组中只有一值个是不重复的,其他的值都是有两个重复的值,找出不重复的那个值。{11,11,12,13,13,16,16}解析为当用Java来解决这个问题时,可以使用异或运算来找出只出现一次的元素。以下是一个示例Java程序,演示了如何在一个整型数组中找出只出现一次的元......
  • 洛谷P5322 [BJOI2019] 排兵布阵 题解
    代码#include<bits/stdc++.h>usingnamespacestd;#defineintlonglongintdp[20001],a[101][101],s,n,m;signedmain(){ cin>>s>>n>>m; for(intj=1;j<=s;j++){ for(inti=1;i<=n;i++){ cin>>a[i][j]; } } for(inti=1;......
  • 局域网内两台设备只有一方可以ping通问题解决
    场景局域网内有两台笔记本,都是windows系统,都是连接的同一个路由器,在同一个网段中。但是其中的一台笔记本192.168.1.101,另外一台是192.168.1.100ping命令测试发现192.168.1.101无法ping通192.168.1.100这是为什么呢?排查与修复首先的两台电脑为了安全,防火墙都是开启的。既然......
  • Atcoder [AGC006D] Median Pyramid Hard 题解 [ 紫 ] [ 二分 ] [ adhoc ]
    MedianPyramidHard:二分trick加上性质观察题。trick我们可以二分值域,然后把大于等于它的数标记成\(1\),其他标记为\(0\)(有些题需要标记成\(-1\)),然后根据这个来check方案是否可行,这通常通过判断某个数是否是\(1\)来实现。本质上其实就是check大于等于它的数能否成为......
  • mac游戏:魔兽争霸3冰封王座Warcraft III for mac 版
    游戏背景设定在魔兽世界的广阔舞台上,玩家将参与到一场场史诗般的战役中。在《冰封王座》中,新增了两个大系列的剧情战役,进一步丰富了游戏的故事情节。这些战役围绕着伊利丹·怒风、阿尔萨斯等经典角色展开,讲述了他们在燃烧军团入侵、巫妖王力量复苏等关键事件中的冒险与斗争。......
  • 82. 删除排序链表中的重复元素 II
    传送锚点:力扣给你一个链表的头节点head和一个整数val,请你删除链表中所有满足Node.val==val的节点,并返回新的头节点。示例1:输入:head=[1,2,6,3,4,5,6],val=6输出:[1,2,3,4,5]示例2:输入:head=[],val=1输出:[]示例3:输入:head=[7,7,7,7],val=7输......