2019 CCPC-Wannafly Winter Camp Day3(Div2, onsite)
solve 4/11
补题:5/11
Code:pai爷 zz
Thinking :pai爷
打表找规律,1张牌 10个不可能的 2张牌有 43 种不可能的 3张牌 有74 种不可能的 4 张牌有 5 种不可能的
#include<iostream>
#include<cstring>
#include<cmath>
#include<cstdlib>
#include<cstdio>
#include<algorithm>
#include<string>
#include<map>
#include<queue>
#include<vector>
#include<stack>
#define ll long long
#define maxn 401000
int main()
{
int n,a[];
while(scanf("%d",&n)!=EOF)
{
for(int i=;i<=n;i++) scanf("%d",&a[i]);
if(n==) printf("32\n");
else printf("891\n");
}
}
分类加二分
留坑
生成树状压dp dp[ s ] [ i ] 表示s状态(节点组成)下,以i为根的树的信息。
留坑
Code:pai爷
Thinking:pai爷
莫比乌斯反演简单题
#include<iostream>
#include<cstring>
#include<cmath>
#include<cstdlib>
#include<cstdio>
#include<algorithm>
#include<string>
#include<map>
#include<queue>
#include<vector>
#include<stack>
#define ll long long
#define maxn 401000
const int P=;
using namespace std;
inline int rd()
{
int x=,f=;char ch=getchar();
while(ch<''||ch>''){if(ch=='-')f=-;ch=getchar();}
while(ch>=''&&ch<=''){x=x*+ch-'';ch=getchar();}
return x*f;
}
int tot;
int a,b,c,d,k,n,l;
int sum[],mu[],pri[],X[],Y[];
bool mark[];
void getmu()
{
mu[]=;
for(int i=;i<=;i++)
{
if(!mark[i]){mu[i]=-;pri[++tot]=i;}
for(int j=;j<=tot&&i*pri[j]<=;j++)
{
mark[i*pri[j]]=;
if(i%pri[j]==) { mu[i*pri[j]]=;break; }
else mu[i*pri[j]]=-mu[i];
}
}
for(int i=;i<=;i++) sum[i]=sum[i-]+mu[i];
}
int cal(int n,int m)
{
if(n>m) swap(n,m);
int ans=,pos;
for(int i=;i<=n;i=pos+)
{
pos=min(n/(n/i),m/(m/i));
ans=(ans+1ll*(sum[pos]-sum[i-])*(n/i)*(m/i))%P;
}
return ans;
}
int main()
{
getmu();
scanf("%d",&n);
for(int i=;i<=n;i++)
if(mu[i]!=)
{
X[++l]=i;
Y[l]=mu[i];
}
ll su=;
for(int i=;i<=l;i++)
{
a=;b=n;c=;d=n;k=X[i];
a--;c--;
a/=k;b/=k;c/=k;d/=k;
ll ans=cal(b,d);
if(Y[i]==) su=(su+ans+P)% P;
else su=(su-ans+P)%P;
}
printf("%lld\n",su);
}
G 排列
Code:zz
Thinking:zz
原序列p的前缀最小值数组肯定是非递增的,如果原序列p是递减的,那么q是递减的,否则,如果出现“1,2,3”这种排列,它的前缀最小数组是“1,1,1”,后一位是小于等于前一位的,q是“1,2,3”,这样q的这种部分就会出现递增的情况。因此,从前往后遍历整个q数组,如果递减,那么对应位置的p排列的地方就应该尽量小;如果遇到递增的地方,那么那片地方的数对应的p排列的地方应该尽量大,并且为了字典序最小,p排列的那片地方应该递增。
//#pragma comment(linker, "/STACK:102400000,102400000")
#include<iostream>
#include<stdio.h>
#include<stdlib.h>
#include<string.h>
#include<string>
#include<math.h>
#include<cmath>
#include<time.h>
#include<map>
#include<set>
#include<vector>
#include<queue>
#include<algorithm>
#include<numeric>
#include<stack>
#include<bitset>
#include<unordered_map>
const int maxn = 0x3f3f3f3f;
const double EI = 2.71828182845904523536028747135266249775724709369995957496696762772407663035354594571382178525166427;
const double PI = 3.141592653589793238462643383279;
using namespace std;
int c[],ans[];
int main(void)
{
//ios::sync_with_stdio(false);
int n,i,z1,z2,pos1,pos2,j;
while(~scanf("%d",&n))
{
for(i = ;i <= n;i++)
{
scanf("%d",c + i);
}
z1 = ;
z2 = n;
for(i = ;i <= n;)
{
if(c[i] == z2)
{
//printf(" %d %d %d\n",i,c[i],z1);
ans[c[i]] = z1++;
//printf("%d %d %d\n",ans[c[i]],c[i],ans[5]);
i++;
}
else
{
ans[c[i]] = z1++;
i++;
pos1 = i;
for(;i <= n;i++)
{
if(c[i] == c[i - ] + )
{
ans[c[i]] = z2--;
}
else
{
break;
}
} pos2 = i - ;
// printf("* %d %d\n",pos1,pos2);
for(j = pos1;pos1 < pos2 && j <= pos1 + (pos2 - pos1) / ;j++)
{
// printf("1111 %d %d %d %d %d %d\n",c[j],c[pos2 - j + pos1],ans[c[j]],c[pos2 - j + pos1],j,pos2 - j + pos1);
int tmp = ans[c[j]];
ans[c[j]] = ans[c[pos2 - j + pos1]];
ans[c[pos2 - j + pos1]] = tmp;
// printf("2222 %d %d %d %d\n",c[j],c[pos2 - j + pos1],ans[c[j]],c[pos2 - j + pos1]);
}
}
}
//printf(" %d\n",ans[5]);
for(i = ;i <= n;i++)
{
printf("%d",ans[i]);
if(i != n)
{
printf(" ");
}
}
printf("\n");
}
return ;
}
Code:pai爷
Thinking:pai爷
差分约束+逆元
#include<iostream>
#include<cstring>
#include<cmath>
#include<cstdlib>
#include<cstdio>
#include<algorithm>
#include<string>
#include<map>
#include<queue>
#include<vector>
#include<stack>
#define ll long long
#define maxn 401000
const int p=;
int f[][],ans[][],z[][];
int n,m,q,l,r,a,b,c,d,an=;
ll qpow(ll a,ll b,ll p)
{
ll ret=;a%=p;
while(b)
{
if(b&) ret=ret*a%p;
b/=;a=a*a%p;
}
return ret;
}
void init()
{
for(int i=;i<=;i++)
{
f[i][]=i*(i+)/;
for(int j=;j<=i;j++)
f[i][j]=(i-j+)*j;
}
}
int main()
{
init();
scanf("%d%d%d",&n,&m,&q);
for(int i=;i<=n;i++)
{
scanf("%d%d",&l,&r);
for(int j=l;j<=r;j++)
{
int sp=r-l+;
ans[i][j]=1ll*f[sp][j-l+]*qpow(f[sp][],p-,p)%p;
}
}
for(int i=;i<=q;i++)
{
scanf("%d%d%d%d",&a,&b,&c,&d);
for(int j=a;j<=c;j++)
{
z[j][b]++;
z[j][d+]--;
}
}
for(int i=;i<=n;i++)
for(int j=;j<=m;j++) z[i][j]+=z[i][j-];
for(int i=;i<=n;i++)
for(int j=;j<=m;j++)
if(z[i][j]==)
{
an=(an+ans[i][j])%p;
}
printf("%d\n",an);
}
带权并查集 (树好像也可以做?)
补题:kk
按照题意描述,所有y挑战x的关系最后会形成一棵树的结构,n个人的总方案数是 3n 种,假设一个人被挑战(主场作战)a次,挑战别人(客场)b次,那么这个人存活到最后的方案数就是3n*(2/3)a*(1/3)b
也就是我们知道这个a和b就可以得到答案了,那要怎么维护呢。
这里用到并查集(jls niub!)
我们用w表示一个节点总共比赛的场次数,v表示主场作战的场次数,如果我们现在把y这个集合并向x这个集合(y挑战x),那么对于XW和Xv肯定都加一,而Yw也加一,如果我们接下来能很好的合并这些信息,那我们就AC了。
这里想了很久,才想明白要怎么做。我们先考虑暴力一点的并查集,就是不路径压缩,那每个节点就可以向上把所有父节点的信息全部加起来,就是我们最后要的某一个节点的W和V了,但是这样做会TLE,因为我们没有路径压缩,查找的时间复杂度很可能退化成O(n),但是我们又不能路径压缩(为什么不行,大家可以尝试一下,反正我自闭了一下午加一晚上)。
普通的带权并查集我们用的都是路径压缩版本的,而这里我们要按秩合并,这样查找的时间复杂度就可以被优化到O(logn)。
曾经我一直以为带权并查集的路径压缩和按秩合并是同一个东西,这道题真的学到了。。
#include<bits/stdc++.h>
#define CLR(a,b) memset(a,b,sizeof(a))
using namespace std;
typedef long long ll;
const int maxn=;
int fa[maxn],Rank[maxn];
ll w[maxn],v[maxn];
int n,m;
int op,x,y;
ll p= ;
struct node{
int fx;
ll w,v;
};
ll qpow(ll a,ll b){
a%=p;
ll res=;
while(b>)
{
if(b&){
res*=a;
res%=p;
}
b>>=;
a=a*a%p;
}
return res;
}
void init(){
for(int i=;i<=n;i++){
fa[i]=i;
w[i]=;
v[i]=;
Rank[i]=;
}
}
node find(int x){
if(x==fa[x]) return {fa[x],w[x],v[x]}; int tep=fa[x];
node e;
e.w=w[x],e.v=v[x];
while(tep!=fa[tep]){
e.w+=w[tep],e.v+=v[tep];
tep=fa[tep];
}
e.fx=tep;
e.v+=v[tep],e.w+=w[tep];
return e;
} void baba(int x,int y){
node ex=find(x),ey=find(y);
if(ex.fx!=ey.fx){
w[ex.fx]+=;
v[ex.fx]+=;
w[ey.fx]+=;
v[ey.fx]+=;
if(Rank[ex.fx]>=Rank[ey.fx])
{
w[ey.fx]-=w[ex.fx];
v[ey.fx]-=v[ex.fx];
fa[ey.fx]=ex.fx;
Rank[ex.fx]++;
}else{
w[ex.fx]-=w[ey.fx];
v[ex.fx]-=v[ey.fx];
fa[ex.fx]=ey.fx;
Rank[ey.fx]++;
} }
}
int main(){
while(cin>>n>>m)
{
init();
ll res=qpow(,n);
ll ans;
while(m--)
{
scanf("%d%d",&op,&x);
if(op==){
scanf("%d",&y);
baba(x,y);
}else{
node ex=find(x);
ll a=ex.v;
ll b=ex.w-ex.v;
ans=res*qpow(qpow(,b),p-)%p*qpow(,a)%p*qpow(qpow(, a),p-)%p;
printf("%lld\n",ans);
}
}
}
}
训练总结:
kk:今日贼菜,0贡献,键盘都没摸一下,石头剪刀布想到用带权并查集表示关系,但不会算情况数是多少,然后就换想法了?自己会的东西还是太少了,pai爷牛逼,zz牛逼!
pai爷:今天24点题目读错背锅了,之后知道是这样的就打表找不可能的情况,花了很多时间。整个人状态不是很好,做题缺少了节奏。最后一小时没有什么想法。
zz:今天做了一道签到题以后就开始跟着金老师研究24点,但是除了手写打表没什么贡献,后来又想了石头剪刀布和几何题,都没什么想法,最后也没做出来。
2019 CCPC-Wannafly Winter Camp Day3(Div2, onsite)的更多相关文章
- CCPC-Wannafly Winter Camp Day3 (Div2, onsite)
Replay Dup4: 没想清楚就动手写? 写了两百行发现没用?想的还是不够仔细啊. 要有莽一莽的精神 X: 感觉今天没啥输出啊, 就推了个公式?抄了个板子, 然后就一直自闭A. 语文差,题目没理解 ...
- 2020 CCPC Wannafly Winter Camp Day1 C. 染色图
2020 CCPC Wannafly Winter Camp Day1 C. 染色图 定义一张无向图 G=⟨V,E⟩ 是 k 可染色的当且仅当存在函数 f:V↦{1,2,⋯,k} 满足对于 G 中的任 ...
- 2019 CCPC-Wannafly Winter Camp Day1 (Div2, onsite)
solve:4/11 补题:6/11 A 机器人 补题:zz 这是一道分类讨论的题目,有一个规律就是如果必须要从第一个区到第二个区,那么最多转区两次(1到2一次,2到1一次),然后分类讨论即可,只要细 ...
- 2019 CCPC-Wannafly Winter Camp Day7(Div2, onsite)
solve 6/11 补题: A.迷宫 Code:zz Thinking:zz kk 把每个节点的深度都处理出来,同一深度的点的冲突度为 (x-1),x为同层次点数减一. 然后冲突度不断下传(冲突度为 ...
- 2019 CCPC-Wannafly Winter Camp Day2(Div2, onsite)
solve 4/11 A Erase Numbers II Code:KK Thinking :KK 用ans表示当前最优答案,maxx表示遍历到的最大数字,一开始ans肯定等于a[ 1 ]+a[ 2 ...
- 2019 CCPC-Wannafly Winter Camp Day4(Div2, onsite)
slove 6/11 A.夺宝奇兵 Code:zz Thinking:zz 贪心即可.这条路线里,点n1和点n2肯定是相连的,接下来,点(n-1)1和点(n-1)2分别是和n1和点n2相连的,一共有两 ...
- 2019 CCPC-Wannafly Winter Camp Day5(Div2, onsite)
solve 5/11 补题:7/11 A Cactus Draw Code:zz Thinking :zz 题意:要在n*n的网格内画上一棵节点数为n树,使得没有边相交. 很好想的构造题,因为网格有n ...
- CCPC Wannafly Winter Camp Div2 部分题解
Day 1, Div 2, Prob. B - 吃豆豆 题目大意 wls有一个\(n\)行\(m\)列的棋盘,对于第\(i\)行第\(j\)列的格子,每过\(T[i][j]\)秒会在上面出现一个糖果, ...
- CCPC-Wannafly Winter Camp Day5 (Div2, onsite) Sorting(线段树)
题目链接 题意 对序列进行三种操作: 1.区间求和. 2.将区间小于等于$x$的数不改变相对顺序的前提下放到$x$左边,用同样规则将比$x$大的放到右边. 3.将区间大于$x$的数不改变相对顺序的前提 ...
随机推荐
- tp5 whereOr
题目:查询grade=1 or class=2 or sex=3的学生 $condition[; $condition[; $condition[; $list =Db::name($this-> ...
- Debian/Linux系统安全配置教程
禁止root SSH登陆 配置SSH Key 配置iptables 当我们安装完Linux系统作为服务器后,总有一系列的安全配置需要进行.特别是当你的服务器Ip是对外网开放的话.全世界有很多不怀好意的 ...
- STM32F4通用定时器
1.基本原理 三种定时器区别 通用定时器功能特点描述 在这里只用输入捕获事件也能获取脉冲个数同时可以只使用它来获取脉冲宽度,比如当捕获到上升沿,马上进入中断,把计数器的值置零,然后等待捕获下降沿的到来 ...
- RabbitMQ的四种ExChange
在message到达Exchange后,Exchange会根据route规则进入对应的Queue中,message可能进入一个Queue也可能进入对应多个Queue,至于进入哪个Queue或者是说哪个 ...
- 【转】jvm 堆内存 栈内存 大小设置
原文地址:http://blog.csdn.net/qh_java/article/details/46608395 4种方式配置不同作用域的jvm的堆栈内存! 1.Eclise 中设置jvm内存: ...
- 阿里云OSS-web直传---在服务端c#签名,浏览器直传
OSS web直传---在服务端php签名,浏览器直传 本文:OSS web直传---在服务端c#签名,浏览器直传 其他语言的范例地址:https://help.aliyun.com/document ...
- ScreenCapture-drupal 7.34-ckeditor4x整合教程
1.1. drupal 7x-ckeditor4x 插件下载:Drupal 7x, 1.1.1. 安装ckeditor4x 下载插件 说明:下载并解压 CKEditor4x插件:https://yun ...
- 20169214 2016-2017-2 《网络攻防实践》第十一周实验 SQL注入
20169214 2016-2017-2 <网络攻防实践>SQL注入实验 SQL注入技术是利用web应用程序和数据库服务器之间的接口来篡改网站内容的攻击技术.通过把SQL命令插入到Web表 ...
- 12306GT多线程、分流免费抢票工具使用心德
大事记背景 我相信很多远游他乡的朋友每逢佳节都会遇到一个难题,就是购票难,这个难题有多难呢?经常在12306官网购票的小伙伴应该知道每个地方的放票时间是不一样的,但是逢年过节的那几天即使你在放票几分钟 ...
- VS中ashx文件关键字没有高亮标记的解决办法
VS --- 工具 --- 选项 --- 文本编辑器 --- 文件扩展名,只要在右侧添加 ashx ,选中MS-VS c# 保存后