BZOJ_1998_[Hnoi2010]Fsk物品调度_并查集+置换
BZOJ_1998_[Hnoi2010]Fsk物品调度_并查集+置换
Description
Input
第一行包含一个整数t,表示数据组数。接下来t行,每行6个数,n,s,q,p,m,d意义如上所述。 对于30%的数据n<=100,对于100%的数据t<=20,n<=100000,s
Output
Sample Input
8 3 5 2 7 4
Sample Output
HINT
说明:第1个到第7个盒子的最终位置依次是:2 5 6 4 1 0 7
一开始没看懂题....
考虑先求出pos,题中已经给出了限制:如果有多个xi,yi满足要求,你需要选择yi最小的,当yi相同时选择xi最小的。
暴力怎么做,在ci这个位置,先看y=0时有没有剩下的,再看y=1....,然后找到一个最小的x。
相当于先+1+1+1再+d+d+d,考虑用并查集来维护删除过程。
两个并查集分别维护+1和+d,当+d的并查集出现环,说明这个环的都取走了,就更新+1的那个并查集。
pos求完了,对于每个环(大小为siz),如果环里有0,贡献为siz-1,否则贡献为siz+1。
代码:
#include <cstdio>
#include <cstring>
#include <algorithm>
using namespace std;
typedef long long ll;
#define N 100050
int n,s,q,p,m,d,C[N],f1[N],f2[N],pos[N],vis[N];
int find1(int x) {return f1[x]==x?x:f1[x]=find1(f1[x]);}
int find2(int x) {return f2[x]==x?x:f2[x]=find2(f2[x]);}
int tx(int x) {return (x+d)%n;}
int ty(int x) {return (x+1)%n;}
void del(int x) {
if(find1(tx(x))==x) {
int y;
f2[x]=find2(ty(x)); for(y=x;tx(y)!=x;y=tx(y),f2[y]=find2(ty(y)));
}else {
f1[x]=find1(tx(x));
}
}
void solve() {
scanf("%d%d%d%d%d%d",&n,&s,&q,&p,&m,&d);
int i;
for(C[0]=0,i=1;i<n;i++) C[i]=(ll(C[i-1])*q+p)%m;
for(i=1;i<n;i++) C[i]=C[i]%n,f1[i]=f2[i]=i; f1[0]=f2[0]=0;
del(s); pos[0]=s;
for(i=1;i<n;i++) {
int p=C[i];
pos[i]=find1(find2(p));
del(pos[i]);
}
// for(i=0;i<n;i++) printf("%d\n",pos[i]);
memset(vis,0,sizeof(vis));
int ans=0;
for(i=0;i<n;i++) if(!vis[i]) {
int j,siz=1,flg=(i==0);
for(vis[j=i]=1;pos[j]!=i;j=pos[j],vis[j]=1,siz++) if(pos[j]==0) flg=1;
if(siz==1) continue;
if(flg) ans+=siz-1;
else ans+=siz+1;
}
printf("%d\n",ans);
}
int main() {
int T;
scanf("%d",&T);
while(T--) solve();
}
BZOJ_1998_[Hnoi2010]Fsk物品调度_并查集+置换的更多相关文章
- BZOJ 1998: [Hnoi2010]Fsk物品调度 [置换群 并查集]
传送门 流水线上有n个位置,从0到n-1依次编号,一开始0号位置空,其它的位置i上有编号为i的盒子.Lostmonkey要按照以下规则重新排列这些盒子. 规则由5个数描述,q,p,m,d,s,s表示空 ...
- 【BZOJ 1998】[Hnoi2010]Fsk物品调度 置换群+并查集
置换群的部分水得一比,据说是经典的置换群理论(然而我并不知道这理论是啥).重点就在于怎么求pos!!!容易发现这个东西是这样的:每次寻找pos,先在本环里找,找不到再往下一个环里找,直到找到为止……一 ...
- 【BZOJ 1998】 1998: [Hnoi2010]Fsk物品调度(双向链表+并查集+置换)
1998: [Hnoi2010]Fsk物品调度 Description 现在找工作不容易,Lostmonkey费了好大劲才得到fsk公司基层流水线操作员的职位.流水线上有n个位置,从0到n-1依次编号 ...
- [BZOJ1998][Hnoi2010]Fsk物品调度
[BZOJ1998][Hnoi2010]Fsk物品调度 试题描述 现在找工作不容易,Lostmonkey费了好大劲才得到fsk公司基层流水线操作员的职位.流水线上有n个位置,从0到n-1依次编号,一开 ...
- 【BZOJ1998】[HNOI2010]物品调度(并查集,模拟)
[BZOJ1998][HNOI2010]物品调度(并查集,模拟) 题面 BZOJ,为啥这题都是权限题啊? 洛谷 题解 先不管\(0\)位置是个空,把它也看成一个箱子.那么最终的答案显然和置换循环节的个 ...
- 【BZOJ】1998: [Hnoi2010]Fsk物品调度
http://www.lydsy.com/JudgeOnline/problem.php?id=1998 题意: 给你6个整数$n,s,q,p,m,d$. 有$n$个位置和$n-1$个盒子,位置编号从 ...
- BZOJ_3362_[Usaco2004 Feb]Navigation Nightmare 导航噩梦_并查集
BZOJ_3362_[Usaco2004 Feb]Navigation Nightmare 导航噩梦_并查集 Description 农夫约翰有N(2≤N≤40000)个农场,标号1到N,M( ...
- BZOJ_2303_[Apio2011]方格染色 _并查集
BZOJ_2303_[Apio2011]方格染色 _并查集 Description Sam和他的妹妹Sara有一个包含n × m个方格的 表格.她们想要将其的每个方格都染成红色或蓝色. 出于个人喜好, ...
- BZOJ_1015_[JSOI2008]星球大战_并查集
BZOJ_1015_[JSOI2008]星球大战_并查集 题意:很久以前,在一个遥远的星系,一个黑暗的帝国靠着它的超级武器统治者整个星系.某一天,凭着一个偶然的 机遇,一支反抗军摧毁了帝国的超级武器, ...
随机推荐
- Cocos2d-x 更改文字换行风格 ( cocos2dx change line )
Cocos2dx change line 在 cocos2dx change line 的实现中,我们能够简单的使用 dimensions属性控制换行.使用它仅仅需将相应的參数值传入构造函数,或者调用 ...
- PLSQL怎样导出oracle表结构
tools->export tables 是导出表结构还有数据 tools->export user objects是导出表结构 可以用tools->export tables ...
- vs2013数据库连接对应的dll
mysql for visual studio 1.1.1mysql connector net 6.3.9mysql connector/odbc 5.3
- Spring MVC获得HttpServletRequest
以下代码是获得Spring MVC中的HttpServletRequest ServletRequestAttributes attr = (ServletRequestAttributes) Req ...
- Android 超高仿微信图片选择器 图片该这么载入
转载请标明出处:http://blog.csdn.net/lmj623565791/article/details/39943731,本文出自:[张鸿洋的博客] 1.概述 关于手机图片载入器,在当今像 ...
- Java知识点梳理——常用方法总结
1.查找字符串最后一次出现的位置 String str = "my name is zzw"; int lastIndex = str.lastIndexOf("zzw& ...
- 九度OJ 1043:Day of Week(星期几) (日期计算)
时间限制:1 秒 内存限制:32 兆 特殊判题:否 提交:5349 解决:1923 题目描述: We now use the Gregorian style of dating in Russia. ...
- Richard Stallman's computer
What hardware do you use? I am using a Lemote Yeelong, a netbook with a Loongson chip and a 9-inch d ...
- iOS 转场动画核心内容
CATransition——转场动画 CATransition是CAAnimation的子类,用于做转场动画,能够为层提供移出屏幕和移入屏幕的动画效果.iOS比Mac OS X的转场动画效果少一点. ...
- Failed to load http://wantTOgo.com/get_sts_token/: No 'Access-Control-Allow-Origin' header is present on the requested resource. Origin 'http://fromHere.com' is therefore not allowed access.
Failed to load http://wantTOgo.com/get_sts_token/: No 'Access-Control-Allow-Origin' header is presen ...