失踪人口回归。撒花\^o^/

说来真是惭愧,NOI之后就没怎么刷过题,就写了几道集训队作业题,打了几场比赛还烂的不行,atcoder至今是蓝名=.=

以后还是多更一些博客吧,我可不想清华集训的时候就退役

A - XXFESTIVAL

题意:输入XXFESTIVAL,输出XX。。。

#include<bits/stdc++.h>
using namespace std;
char s[1005];
int main()
{
scanf("%s",s);
int n=strlen(s);
for(int i=0;i<n-8;i++)
{
putchar(s[i]);
}
cout<<endl;
return 0;
}

  

B - Problem Set

题意:

有n个人,每人有个值di,m个问题,每个问题有个值ti,一个人可以解决值相同的问题,问能不能全部解决。

n,m<=200000

用个map每次在里边查就行了。

#include<bits/stdc++.h>
#define N 200005
using namespace std;
int n,m;
map<int,int>mp;
int a[N],b[N];
int main()
{
cin>>n;
for(int i=1;i<=n;i++)scanf("%d",&a[i]),mp[a[i]]++;
cin>>m;
for(int i=1;i<=m;i++)
{
scanf("%d",&b[i]);
if(mp[b[i]]<=0)
{
puts("NO");
return 0;
}
mp[b[i]]-=1;
}
puts("YES");
return 0;
sort(a+1,a+n+1);
sort(b+1,b+m+1);
if(n<m)
{
puts("NO");
}
else
{
for(int i=n;i>=n-m+1;i--)
{
if(b[m-n+i]>a[i])
{
puts("NO");
return 0;
}
}
puts("YES");
}
return 0;
}

  

C - 3 Steps

题意:

给一个连通图,如果一个点u能走三条边到达v,并且uv之间没有边,那么可以在他们之间连一条边,不停的连,问最多能连几条边。

2≤N≤105

把这张图黑白染色,如果不是二分图,那么所有边都可以连上,否则只能在黑白点之间连边。

证明的话,显然一个白点走三步只能到一个黑点,连完边之后依然是个二分图,一点一点连的话显然所有能连的边都能连上。

#include<bits/stdc++.h>
#define N 200005
using namespace std;
int n,m;
int head[N],ver[N],nxt[N],tot;
void add(int a,int b)
{
tot++;nxt[tot]=head[a];head[a]=tot;ver[tot]=b;return ;
}
int v[N],flag,tt1,tt2;
void dfs(int x,int c)
{
if(c)tt1++;
else tt2++;
v[x]=c;
for(int i=head[x];i;i=nxt[i])
{
if(v[ver[i]]==-1)dfs(ver[i],c^1);
else if(v[ver[i]]!=(c^1))
{
flag=1;
}
}
}
int main()
{
cin>>n>>m;
int t1,t2;
for(int i=1;i<=m;i++)
{
scanf("%d%d",&t1,&t2);
add(t1,t2);add(t2,t1);
}
memset(v,-1,sizeof(v));
dfs(1,1);long long ans;
if(flag)
{
ans=1LL*n*(n-1)/2-m;
}
else
{
ans=1LL*tt1*tt2-m;
}
cout<<ans<<endl;
return 0;
}

  

D - 101 to 010

题意:

有一个01序列,每次可以选出其中的一个101,变成010,问最优策略下能操作几次。

N<=500000

这题比赛的时候做了一年。。。

把101->010看做一次反应,我们发现对于发生需要有先后顺序的反应的一段只能长成1011111....或....1111101。

这样我们可以把序列分成很多段,每一段自己反应。

分段的话DP一下就好了。

#include<bits/stdc++.h>
#define N 500005
using namespace std;
int n,a[N],f[N],g[N],l[N],h[N],p[N],q[N];
char s[N];
int main()
{
cin>>n;scanf("%s",s+1);
for(int i=1;i<=n;i++)a[i]=s[i]-'0';
memset(g,0xcf,sizeof(g));
memset(l,0xcf,sizeof(l));
memset(h,0xcf,sizeof(h));
memset(p,0xcf,sizeof(p));
memset(q,0xcf,sizeof(q));
for(int i=1;i<=n;i++)
{
if(a[i]==1)
{
g[i]=f[i-1];
h[i]=max(f[i-1],h[i-1])+1;
l[i]=max(q[i-1],l[i-1])+1;
f[i]=p[i-1];
}
else
{
p[i]=h[i-1];
q[i]=g[i-1];
}
f[i]=max(f[i],max(f[i-1],l[i]));
}
cout<<f[n]<<endl;
return 0;
}

  

E - Popping Balls

题意:

有A个红球和B个蓝球排成一列,蓝球排在红球后。

可以选择一个s和t,s,t<=A+B

每次从第一个,或第s个,或第t个位置取出一个球。

问对于所有的s和t,最后的取出序列V有多少种,颜色相同的球没有区别。

A,B<=2000

这题做了十年。。。

我们先枚举V的开头有多少个红球,假设是i个,那么我们贪心的把t(不妨让t>s)设为A-i+1,因为t越小越好,第i+1个必须是蓝球。

再枚举取到剩下t-1个球时还有多少个红球j,此时还有A-i-j个蓝球。

从开始到达这个状态的方案数是$C_{B-1}^{B-1-(A-i-j)}$(之后又取走了B-1个球,其中有B-1-(A-i-j)个蓝球)。

之后的问题变为有A个红球和B个蓝球,只能选一个s,问取完的方案数。

大概是$$\sum_{k=0}^{j}\sum_{l=0}^{j-k}C_{A-i-j-1}^{l}$$

就是组合数某一行的前缀和的前缀和。

#include<bits/stdc++.h>
#define N 2005
using namespace std;
int c[N][N],s[N][N],w[N][N];
const int p = 1000000007;
int A,B;
int main()
{
for(int i=0;i<N;i++)
{
c[i][0]=s[i][0]=1;
w[i][0]=i+1;
for(int j=1;j<=i;j++)
{
c[i][j]=(c[i-1][j]+c[i-1][j-1])%p;
s[i][j]=(s[i][j-1]+c[i][j])%p;
w[i][j]=1LL*c[i][j]*(i-j+1)%p;
(w[i][j]+=w[i][j-1])%=p;
}
}
cin>>A>>B;
int ans=1;
for(int i=0;i<A;i++)
{
for(int j=0;j<=A-i;j++)
{
if(A-i-j==0){ans++;continue;}
if(j+B-1<A-i)continue;
int q=0;
if(j>=A-i-j-1)
{
q=w[A-i-j-1][A-i-j-1]+1LL*(j-A+i+j+1)*s[A-i-j-1][A-i-j-1]%p;
q%=p;
}
else
{
q=w[A-i-j-1][j]-1LL*(A-i-j-1-j)*s[A-i-j-1][j]%p;
q=(q+p)%p;
}
ans=(ans+1LL*c[B-1][A-i-j]*q%p)%p;
}
}
cout<<ans%p<<endl;
return 0;
}

  

F - Largest Smallest Cyclic Shift

题意:

给出X个‘a’,Y个'b',Z个‘c’,让你排列成一个字符串,使得最小表示最大。

输出最小表示。

X+Y+Z<=50

参考CF上某神犇的解法。

先把所有字母放到一个multiset<string>里,每回取出最小的字符串和最大的字符串拼在一起放回去,知道只剩一个字符串,输出。

贪心嘛,一个字符串太小了肯定要用大的往后拽,正确性大概YY一下就好了。

#include<bits/stdc++.h>
using namespace std;
int a,b,c;
multiset<string>s;
int main()
{
cin>>a>>b>>c;
for(int i=1;i<=a;i++)s.insert("a");
for(int i=1;i<=b;i++)s.insert("b");
for(int i=1;i<=c;i++)s.insert("c");
while(s.size()>1)
{
string ss=(*s.begin())+(*s.rbegin());
s.erase(s.begin());
s.erase(--s.end());
s.insert(ss);
}
cout<<(*s.begin());
return 0;
}

  

CODE FESTIVAL 2017 qual B 题解的更多相关文章

  1. CODE FESTIVAL 2017 qual A 题解

    补一发A的题解. A - Snuke's favorite YAKINIKU 题意: 输入字符串S,如果以YAKI开头输出Yes,否则输出No. #include<bits/stdc++.h&g ...

  2. CODE FESTIVAL 2017 qual C 题解

    传送门 \(A\) 咕咕 const int N=15; char s[N];int n; int main(){ scanf("%s",s+1),n=strlen(s+1); f ...

  3. CODE FESTIVAL 2017 qual B C - 3 Steps【二分图】

    CODE FESTIVAL 2017 qual B C - 3 Steps 题意:给定一个n个结点m条边的无向图,若两点间走三步可以到,那么两点间可以直接连一条边,已经有边的不能连,问一共最多能连多少 ...

  4. CODE FESTIVAL 2017 qual B B - Problem Set【水题,stl map】

    CODE FESTIVAL 2017 qual B B - Problem Set 确实水题,但当时没想到map,用sort后逐个比较解决的,感觉麻烦些,虽然效率高很多.map确实好写点. 用map: ...

  5. 题解【AtCoder - CODE FESTIVAL 2017 qual B - D - 101 to 010】

    题目:https://atcoder.jp/contests/code-festival-2017-qualb/tasks/code_festival_2017_qualb_d 题意:给一个 01 串 ...

  6. 【题解】Popping Balls AtCoder Code Festival 2017 qual B E 组合计数

    蒟蒻__stdcall终于更新博客辣~ 一下午+一晚上=一道计数题QAQ 为什么计数题都这么玄学啊QAQ Prelude 题目链接:这里是传送门= ̄ω ̄= 下面我将分几个步骤讲一下这个题的做法,大家不 ...

  7. Atcoder Code Festival 2017 qual C 10.22 D题题解

    [题意概述] 给出一个只有小写字母的序列,问最少把序列分成几段可以满足每一段可以通过变换成为回文串.变换指的是交换子序列中的字母的位置. [题解] 我们把a~z分别设为2^0~2^25,每个子序列满足 ...

  8. Atcoder CODE FESTIVAL 2017 qual C D - Yet Another Palindrome Partitioning 回文串划分

    题目链接 题意 给定一个字符串(长度\(\leq 2e5\)),将其划分成尽量少的段,使得每段内重新排列后可以成为一个回文串. 题解 分析 每段内重新排列后是一个回文串\(\rightarrow\)该 ...

  9. CODE FESTIVAL 2017 qual B

    昨晚因为有点事就去忙了,没打后悔啊 A - XXFESTIVAL Time limit : 2sec / Memory limit : 256MB Score : 100 points Problem ...

随机推荐

  1. Django Rest Framework源码剖析(一)-----认证

    一.简介 Django REST Framework(简称DRF),是一个用于构建Web API的强大且灵活的工具包. 先说说REST:REST是一种Web API设计标准,是目前比较成熟的一套互联网 ...

  2. 20155227《网络对抗》Exp5 MSF基础应用

    20155227<网络对抗>Exp5 MSF基础应用 基础问题回答 用自己的话解释什么是exploit,payload,encode exploit:把实现设置好的东西送到要攻击的主机里. ...

  3. 20155313 杨瀚 《网络对抗技术》实验一 PC平台逆向破解(5)M

    exp1 PC平台逆向破解(5)M 一.实验内容 1.手工修改可执行文件,改变程序执行流程,直接跳转到getShell函数. 2.利用foo函数的Bof漏洞,构造一个攻击输入字符串,覆盖返回地址,触发 ...

  4. WPF样式(Style)入门

    原文:WPF样式(Style)入门 版权声明:本文为博主原创文章,未经博主允许不得转载. https://blog.csdn.net/qq_34802416/article/details/78231 ...

  5. [python]记录Windows下安装matplot的经历

    最近学习在看<机器学习实战>一书,第二章的时候要用到Natplotlib画图,于是便开始安装Matplotlib.本文所用到的所有安装包都可以在文末的链接中找到. 首先从Matplotli ...

  6. 12、利用docker快速搭建Wordpress网站

    一.准备工作 结构图: 用户访问页面,Nginx将请求进行转发,如果请求的是php页面,则通过FastCGI转发给后端php进行处理:如果非php页面,则直接返回静态页面. 关键点: mysql.ph ...

  7. 2017qq红包雨最强攻略

    这个只支持苹果手机,而且要有苹果电脑,只有苹果手机是不行的. QQ红包规则:只要你到达指定的位置,就可以领取附近的红包,一般也就几毛,还有几分的,当然也不排除有更高的,只不过我是没遇到... 那么既然 ...

  8. linux中使sqlplus能够上下翻页

    安装包链接:https://pan.baidu.com/s/1WsQTeEQClM88aEqIvNi2ag 提取码:s241  rlwrap-0.37-1.el6.x86_64.rpm 和 rlwra ...

  9. Python3 str去除空格

    一.去除str两端空格(strip()) a.去除左端空格  lstrip() str0='abcdef' str1=' abcdef' print(str0) print(str1.lstrip() ...

  10. linux一切皆文件之块设备文件(四)

    一.知识准备 1.在linux中,一切皆为文件,所有不同种类的类型都被抽象成文件(比如:块设备,socket套接字,pipe队列) 2.操作这些不同的类型就像操作文件一样,比如增删改查等 3.块设备是 ...