noi前橙名计划失败。全程搞C而gg……

A - Biscuits

题意:背包,求价值为奇/偶的方案数。

#include<cstdio>
#include<queue>
#include<algorithm>
#define ld long double
#define MN 21000000
using namespace std; int read_p,read_ca;
inline int read(){
read_p=;read_ca=getchar();
while(read_ca<''||read_ca>'') read_ca=getchar();
while(read_ca>=''&&read_ca<='') read_p=read_p*+read_ca-,read_ca=getchar();
return read_p;
}
int n,p,a;
long long mmh[];
int main(){
mmh[]=;
n=read();p=read();
while(n--){
a=read()&;
if (a&){
mmh[]=mmh[]=mmh[]+mmh[];
}else mmh[]<<=,mmh[]<<=;
}
printf("%lld\n",mmh[p]);
}

B - Moderate Differences

题意:询问是否可以把B-A表示成n-1个绝对值在C和D之间的数的和。

#include<cstdio>
#include<queue>
#include<algorithm>
#define ld long double
#define MN 21000000
using namespace std; int read_p,read_ca;
inline int read(){
read_p=;read_ca=getchar();
while(read_ca<''||read_ca>'') read_ca=getchar();
while(read_ca>=''&&read_ca<='') read_p=read_p*+read_ca-,read_ca=getchar();
return read_p;
}
long long n,a,b,c,d,w;
int main(){
scanf("%lld%lld%lld%lld%lld",&n,&a,&b,&c,&d);
b-=a;n--;
for (int i=;i<=n;i++){
w=-d*i+c*(n-i);
if (b-w<=(d-c)*n&&b>=w) return /*printf("%d %lld %lld %lld\n",i,w,n,b-w),*/puts("YES"),;
}
puts("NO");
}

C - Snuke and Spells

题意:定义一种操作为当序列长度为k时把所有等于k的元素删去,问将给定序列至少修改多少元素,序列能进行不断操作后为空。

题解:有一个结论:如果等于 $i$ 的数有$N_{i}$个,那么看成区间$[i-N_{i}+1,i]$,未被区间覆盖的位置数量即为答案。

#include<cstdio>
#include<algorithm>
#define MN 210000
using namespace std; int n,m,x,y,c[MN<<],t[MN],a[MN],mmh=;
int main(){
scanf("%d%d",&n,&m);
for (int i=;i<=n;i++){
scanf("%d",&a[i]);
if (a[i]-t[a[i]]>) mmh+=(c[a[i]-t[a[i]]]++)==;
t[a[i]]++;
}
while (m--){
scanf("%d%d",&x,&y);
t[a[x]]--;
if (a[x]-t[a[x]]>)mmh-=(--c[a[x]-t[a[x]]])==;
a[x]=y;
if (a[x]-t[a[x]]>)mmh+=(c[a[x]-t[a[x]]]++)==;
t[a[x]]++;
printf("%d\n",n-mmh);
}
}

D - Game on Tree

题意:裸删边游戏。

题解:大佬论文

#include<cstdio>
#include<queue>
#include<algorithm>
#define ld long double
#define MN 210000
using namespace std; int read_p,read_ca;
inline int read(){
read_p=;read_ca=getchar();
while(read_ca<''||read_ca>'') read_ca=getchar();
while(read_ca>=''&&read_ca<='') read_p=read_p*+read_ca-,read_ca=getchar();
return read_p;
}
struct na{int y,ne;}b[MN];
int n,m,l[MN],num=,x,y,s[MN];
inline void in(int x,int y){
b[++num].y=y;b[num].ne=l[x];l[x]=num;
}
void dfs(int x,int f){
int u=;s[x]=;
for (int i=l[x];i;i=b[i].ne)
if (b[i].y!=f){
dfs(b[i].y,x);u^=s[b[i].y]+;
} s[x]=u;
/*for (int i=l[x];i;i=b[i].ne)
if (b[i].y!=f){
if ((u^s[b[i].y])==0) s[x]=1;
}*/
//printf("%d %d\n",x,s[x]);
}
int main(){
n=read();
for (int i=;i<n;i++) x=read(),y=read(),in(x,y),in(y,x); dfs(,);
puts(s[]?"Alice":"Bob");
}

E - Jigsaw

题意:问能否把拼图排成一排使得相邻拼图契合。

题解:把拼图看成边,其两段信息作为点连边然后并查集。

#include<cstdio>
#include<algorithm>
#define NO return puts("NO"),0
using namespace std; int n,m,f[],a,b,c,d,x,y,D[],bo[],C[];
int gf(int x){return x==f[x]?x:f[x]=gf(f[x]);}
int main(){
scanf("%d%d",&n,&m); for (int i=;i<;i++) f[i]=i;
while (n--){
scanf("%d%d%d%d",&a,&b,&c,&d);
if (c==) x=a;else x=-c;x+=;
if (d==) y=-b;else y=d;y+=;
f[gf(x)]=gf(y);
D[x]++;D[y]--;bo[x]=;
}
for (int i=;i<;i++) if (D[i]>) NO;
for (int i=;i<;i++) if (D[i]<) NO;
for (int i=;i<;i++)
if (bo[gf(i)]|=bo[i],D[i]) C[f[i]]=;
for (int i=;i<;i++)
if (f[i]==i&&!C[i]&&bo[i]) NO;
puts("YES");
}

F - Zigzag

题意:在$\frac{n*(n+1)}{2}$三角形上从顶到底画m条可重合,不可相交的线,某些线的部分已经确定,求方案数,、

题解:dp[i][j]表示考虑了前$i$条线,第$i$条线的位置状态为$j$的方案数。转移起来有点麻烦,窝看并抄了dalao的代码,实现得非常优雅,大约是从高往低考虑往左走的线可以向往右的线转移。

#include<cstdio>
#include<algorithm>
#define MN 1000
using namespace std; const int MOD=1e9+;
int n,m,k,le[MN],ri[MN],x,y,z,mmh[<<],MMH=;
inline void M(int &x){while(x>=MOD)x-=MOD;}
int lowbit(int x) { return x & -x; }
int main(){
scanf("%d%d%d",&n,&m,&k);n--;
for (int i=;i<=m;i++) le[i]=(<<n)-,ri[i]=;
while(k--){
scanf("%d%d%d",&x,&y,&z);y--;
if (z==) le[x]^=<<y;else ri[x]^=<<y;
}
mmh[]=;
for (int i=;i<=m;i++){
for (int k=;k<n;k++)
for (int j=;j<(<<n);j++) if (~j>>k&)
M(mmh[j+(<<k)-lowbit(j&~((<<k)-))]+=mmh[j]);
for (int j=;j<(<<n);j++)
if (!((j&ri[i])==ri[i]&&(j&le[i])==j)) mmh[j]=;
}
for (int j=;j<(<<n);j++) M(MMH+=mmh[j]);
printf("%d\n",MMH);
}

AtCoder Grand Contest 017的更多相关文章

  1. AtCoder Grand Contest 017 F - Zigzag

    题目传送门:https://agc017.contest.atcoder.jp/tasks/agc017_f 题目大意: 找出\(m\)个长度为\(n\)的二进制数,定义两个二进制数的大小关系如下:若 ...

  2. AtCoder Grand Contest 017 (VP)

    contest link Official Editorial 比赛体验--之前做题的时候感觉 AtCoder 挺快的,现在打了VP之后发现还是会挂的--而且不是加载缓慢或者载不出来,直接给你一个无法 ...

  3. AtCoder Grand Contest 017 题解

    A - Biscuits 题目: 给出 \(n\) 个物品,每个物品有一个权值. 问有多少种选取方式使得物品权值之和 \(\bmod\space 2\) 为 \(p\). \(n \leq 50\) ...

  4. AtCoder Grand Contest 017 迟到记

    晚上去操场上浪. 回来以后看到好几个人开着 \(AtCoder\) 在打代码. ... ... 今天有 \(AtCoder\) 比赛 ? 管它呢, \(Kito\) 在切西瓜,先吃西瓜... 然后看 ...

  5. 题解——ATCoder AtCoder Grand Contest 017 B - Moderate Differences(数学,构造)

    题面 B - Moderate Differences Time limit : 2sec / Memory limit : 256MB Score : 400 points Problem Stat ...

  6. AtCoder Grand Contest 017 B

    B - Moderate Differences Time limit : 2sec / Memory limit : 256MB Score : 400 points Problem Stateme ...

  7. AtCoder Grand Contest 017 A

    Problem Statement There are N bags of biscuits. The i-th bag contains Ai biscuits. Takaki will selec ...

  8. AtCoder Grand Contest 017题解

    传送门 \(A\) 直接转移就是了 typedef long long ll; const int N=55; ll f[N][2];int a[N],n,p; int main(){ scanf(& ...

  9. AtCoder Grand Contest 012

    AtCoder Grand Contest 012 A - AtCoder Group Contest 翻译 有\(3n\)个人,每一个人有一个强大值(看我的假翻译),每三个人可以分成一组,一组的强大 ...

随机推荐

  1. Huffman 哈夫曼编码与译码的原理剖析及C++实现

    原理 我们在信息存储时,希望以最少的空间去存储最大的数据,方便数据的传输,那么该怎样做呢? 我们想到将源信息转化为01序列存储,但是这样以来又有一个问题,就是子串匹配问题,我们为了解决这个方法,想到了 ...

  2. iOS 写给iOS开发者的React Native学习路线(转)

    我是一名iOS开发者,断断续续一年前开始接触React Native,最近由于工作需要,专职学习React Native也有一个多月了.网络上知识资源非常的多,但能让人豁然开朗.迅速学习的还是少数,我 ...

  3. go实例之函数

    1.可变参数 示例代码如下: package main import "fmt" // Here's a function that will take an arbitrary ...

  4. C# 内存模型

    C# 内存模型 This is the first of a two-part series that will tell the long story of the C# memory model. ...

  5. 网关 php-cgi fastcgi phpfpm

    本文同时发表在https://github.com/zhangyachen/zhangyachen.github.io/issues/88 关于网关的理解,一句话就是:作为一种翻译器,抽象出了一种能够 ...

  6. [置顶] 几行代码实现ofo首页小黄人眼睛加速感应转动

    最新版的ofo 小黄车的首页小黄人眼睛随重力而转动,感觉有点炫酷,学习一下吧,以下代码是在xamarin android下实现 ofo首页效果图: xamarin android实现效果: 实现思路: ...

  7. bzoj 1758: [Wc2010]重建计划

    Description Input 第 一行包含一个正整数N,表示X国的城市个数. 第二行包含两个正整数L和U,表示政策要求的第一期重建方案中修建道路数的上下限 接下来的N-1行描述重建小组的原有方案 ...

  8. chattr 命令详解

    chattr   作用: 改变文件属性,这项指令可改变存放在ext2文件系统上的文件或目录属性,这些属性共有一下8种模式 模式: a: 让文件或目录仅供附加用途 b: 不更新文件或目录的最后存取时间 ...

  9. ThreadLocal 线程本地变量 及 源码分析

    ■ ThreadLocal 定义 ThreadLocal通过为每个线程提供一个独立的变量副本解决了变量并发访问的冲突问题 当使用ThreadLocal维护变量时,ThreadLocal为每个使用该变量 ...

  10. 为clang添加中文关键字

    原址: https://zhuanlan.zhihu.com/p/31158537 以clang为基础做了一个与C++.C兼容中英文关键字的编译器 swizl/cnlang 原理就是加与英文关键字等效 ...