【BZOJ2054】疯狂的馒头(并查集)
/*
经典思路, 倒序并查集处理即可
*/
#include<cstdio>
#include<algorithm>
#include<cstring>
#include<queue>
#include<iostream>
#define ll long long
#define mmp make_pair
#define M 1000010
using namespace std;
int read() {
	int nm = 0, f = 1;
	char c = getchar();
	for(; !isdigit(c); c = getchar()) if(c == '-') f = -1;
	for(; isdigit(c); c = getchar()) nm = nm * 10 + c - '0';
	return nm * f;
}
int father[M], cor[M], n, m, p, q;
int find(int x) {
	return father[x] == x ? x : father[x] = find(father[x]);
}
int main() {
	n = read(), m = read(), p = read(), q = read();
	for(int i = 1; i <= n + 1; i++) father[i] = i;
	for(int i = m; i >= 1; i--) {
		int l = (1ll * p * i + q) % n + 1, r = (1ll * i * q + p) % n + 1;
		if(l > r) swap(l, r);
		for(int j = find(l); j <= r; j = find(j + 1)) cor[j] = i, father[j] = find(j + 1);
	}
	for(int i = 1; i <= n; i++) cout << cor[i] << "\n";
	return 0;
}
【BZOJ2054】疯狂的馒头(并查集)的更多相关文章
- BZOJ2054 疯狂的馒头 并查集
		题意:懒得写了有空再补上 链接:http://www.lydsy.com/JudgeOnline/problem.php?id=2054 离线从后往前做,并查集维护下一个没染色的就可以啦- #incl ... 
- Luogu P2391 白雪皑皑 && BZOJ 2054: 疯狂的馒头 并查集
		4月的时候在luogu上做过 白雪皑皑 这道题,当时一遍AC可高兴了qwq,后来去了个厕所,路上忽然发现自己的做法是错的qwq...然后就咕咕了qwq 今天看到了 疯狂的馒头 ,发现一毛一样OvO.. ... 
- 【BZOJ 2054】 2054: 疯狂的馒头 (并查集特技)
		Input 第一行四个正整数N,M,p,q Output 一共输出N行,第i行表示第i个馒头的最终颜色(如果最终颜色是白色就输出0). Sample Input 4 3 2 4 Sample Outp ... 
- Bzoj P2054 疯狂的馒头 | 并查集
		题目链接 思路:因为每次染色都会将某些馒头的颜色彻底更改,所以每个馒头的最终的颜色其实是由最后一次染色决定的,那么我们只考虑最后一次染色即可.对此,我们可以从后往前倒着染色,当目前的染色区间中存在白色 ... 
- BZOJ.2054.疯狂的馒头(并查集)
		BZOJ 倒序处理,就是并查集傻题了.. 并查集就是确定下一个未染色位置的,直接跳到那个位置染.然而我越想越麻烦=-= 以为有线性的做法,发现还是要并查集.. 数据随机线段树也能过去. //18400 ... 
- bzoj2054: 疯狂的馒头(并查集)
		每个区间只被覆盖一次,求每个点被哪种区间覆盖或者某个区间是否已经被覆盖过都可以用并查集做. 做法:每个点都指向当前被覆盖区间的右端点+1的位置,某个点的下一个没被覆盖的点是gf(i),同理如果某个区间 ... 
- 【并查集】bzoj2054 疯狂的馒头
		因为只有最后被染上的颜色会造成影响,所以倒着处理,用并查集维护已经染色的区间的右端点,即fa[i]为i所在的已染色区间的右端点,这样可以保证O(n)的复杂度. #include<cstdio&g ... 
- bzoj2054 疯狂的馒头
		bzoj上现在找不到这题,所以目前只是过了样例,没有测 2054: 疯狂的馒头 Time Limit: 10 Sec Memory Limit: 162 MBSubmit: 715 Solved: ... 
- bzoj2054疯狂的馒头——线段树
		中文题面,一排有n个馒头,用刷子把整个连续的区间刷成一种颜色.因为颜色会覆盖掉之前的.所以我们可以用线段树来反着处理.如果这段区间之前刷到过就不要再遍历进去了,因为这次已经被上次刷的颜色给覆盖了.最后 ... 
- [BZOJ2238]Mst 最小生成树+树链剖分/并查集
		链接 题解 先构建出最小生成树,如果删的是非树边,直接输出答案 否则问题转化为,把该边删掉后剩下两个联通块,两个端点分别在两个块内的最小边权,LCT可以维护 不妨换一种思考方向:考虑一条非树边可以代替 ... 
随机推荐
- AI之旅(3):升维与最小二乘法
			前置知识 矩阵的逆 知识地图 首先我们将了解一种叫升维的方法,用已有特征构造更多的特征.接着通过对空间与投影建立一定的概念后,推导出最小二乘法. 当特征数量不足时 在上一篇<初识线性 ... 
- s21day14 python笔记
			s21day14 python笔记 一.内容回顾及补充 参数补充 对于函数的默认值是可变类型 # 如果要想给value设置默认是空列表 # 不推荐(坑) def func(data,value=[]) ... 
- axios 重复点击利用CancelToken阻止请求多次发送
			import axios from 'axios'; axios.defaults.timeout = 5000; axios.defaults.baseURL =''; let pending = ... 
- maven使用utf8等
			pom.xml: <properties> <project.build.sourceEncoding>UTF-8</project.build.sourceEncodi ... 
- vue day8  table page
			@{ ViewBag.Title = "Home Page"; Layout = null; } <!DOCTYPE html> <html> <he ... 
- ruoyi管理系统建立子项目,卡住
			这个一定不要勾选,不然依赖加了还是引用不到. 
- js设置,获取cookie
			function setCookie(c_name,value,expireMinutes){ var exdate=new Date(); exdate.setMinutes(exdate.getM ... 
- go 的数据类型
			bool string int int8 int16 int32(rune) int64 uint uint8(byte) uint16 uint32 uint64 uintptr:无符号整型,用于存 ... 
- springmvc的dispatchservlet初始化
			初始化做的事情,处理下controller的映射关系 https://blog.csdn.net/qq_38410730/article/details/79426673 
- win 8.1 Your PC needs to be repaired修复过程
			一.问题情况描述: 下班时,执行关闭系统命令,但硬盘灯一直亮着,因急着下班,所以直接长按电源键,装包回家... 到家后一段时间,启动电脑,但电脑蓝屏,提示“Your PC needs to be re ... 
