今天是毕业的学长给高二的同学测试。组队比赛,ACM赛制,于是就愉快的和学姐一队啦。

  看到英文题面感到恐慌,不过好在不难读懂。

  

  A:并没有什么技术含量的模拟题;

  

  B:字符串题,给定一些比赛和每个队胜利的场数,判断是否合法。

  [[a-b]-[c-d]],a 2,b 0,c,1,d 0就是合法的。(意思是:a和b比一场,c和d比一场,两场的胜者再一起比一场)

  递归地读入形成一个树的结构,从最基础的比赛层层check上去。

  

 # include <cstdio>
# include <iostream>
# include <cstring>
# include <string> using namespace std; int l,a,b,v[],x,cnt=,ap=;
bool vis[],f=true;
char p,s[];
struct race
{
int x,y,w;
}r[]; int read (int x)
{
int pos=x+,a,b;
if(s[pos]=='[')
{
pos=read(pos);
a=cnt;
}else
a=s[pos]-'a';
pos+=;
if(s[pos]=='[')
{
pos=read(pos);
b=cnt;
}else
b=s[pos]-'a';
r[++cnt].x=a;
r[cnt].y=b;
return pos+;
} int main()
{
scanf("%s",s+);
read();
l=strlen(s+);
for (int i=;i<=l;++i)
if(s[i]>='a'&&s[i]<='z'&&vis[ s[i]-'a' ]==false)
vis[ s[i]-'a' ]=true,ap++;
for (int i=;i<=ap;++i)
{
cin>>p>>x;
v[p-'a']=x;
}
for (int i=;i<=cnt;++i)
{
race now=r[i];
if(now.x<)
a=now.x;
else
a=r[now.x].w;
if(now.y<)
b=now.y;
else
b=r[now.y].w;
if(v[a]==&&v[b]!=)
{
r[i].w=b;
v[b]--;
}
else if(v[a]!=&&v[b]==)
{
r[i].w=a;
v[a]--;
}
else f=false;
}
for (int i=;i<;++i)
if(v[i]) f=false;
if(f) printf("Yes\n");
else printf("No\n");
return ;
}

B

  C:求在$[l,r]$区间内素因子个数为质数的数。$1<=l,r<=1e9$

  学姐做的这个题,是素数筛一类的思想。

  

 #include <cstdio>
#include <cmath> const int N = ; bool notp[N+];
int prm[N+], tot, a[N+], b[N+], l, r, ans; void prime() {
notp[] = notp[] = ;
for (int i = ; i <= N; ++i) {
if (!notp[i]) prm[++tot] = i;
for (int j = ; i * prm[j] <= N && j <= tot; ++j) {
notp[i*prm[j]] = ;
if (i % prm[j] == ) break;
}
}
} int main() {
scanf("%d%d", &l, &r);
prime();
for (int i = l; i <= r; ++i) b[i-l+] = i;
for (int i = ; i <= tot; ++i) {
if (prm[i] > r) break;
int j = l / prm[i];
if (prm[i] * j < l) ++j;
for (j; prm[i] * j <= r; ++j) {
while (b[prm[i]*j-l+] % prm[i] == )
++a[prm[i]*j-l+], b[prm[i]*j-l+] /= prm[i];
}
}
for (int i = l; i <= r; ++i) {
if (b[i-l+] > ) ++a[i-l+];
if (!notp[a[i-l+]]) ++ans;
}
printf("%d\n", ans);
return ;
}

C

  D,E,F,G:咕咕咕;

  H:点开H题可能是我整场比赛最正确的决定了。正好是我之前想过的一个题,类似于那道L语言,但是要判断方案数,数据范围非常大,但是抱着反正不会交了不亏的思想写了一个交上去,A了...而且还比AC自动机快?果然做题要有信仰。

  

 # include <cstdio>
# include <iostream>
# include <cstring>
# include <string>
# define R register int
# define mod using namespace std; const int maxn=;
int n,cnt=;
char c[];
int ch[maxn][],l;
bool vis[maxn];
int dp[]; inline void ins()
{
int n,x=,l=strlen(c+);
for (R i=;i<=l;++i)
{
n=c[i]-'a';
if(!ch[x][n]) ch[x][n]=++cnt;
x=ch[x][n];
}
vis[x]=true;
} inline void Find (int pos)
{
int x=,n;
for (R i=pos;i<=l;++i)
{
n=c[i]-'a';
if(!ch[x][n]) break;
x=ch[x][n];
if(vis[x])
{
dp[i]+=dp[pos-];
if(dp[i]>=mod) dp[i]-=mod;
}
}
} int main()
{
scanf("%d",&n);
for (R i=;i<=n;++i)
{
scanf("%s",c+);
ins();
}
dp[]=;
scanf("%s",c+);
l=strlen(c+);
for (R i=;i<l;++i)
if(dp[i]) Find(i+);
printf("%d\n",dp[l]);
return ;
}

H

  I,J,K:咕咕咕;

  ---shzr

ACM模拟赛的更多相关文章

  1. 丁酉年六月十一ACM模拟赛

    似乎该写题解了.今天模拟ACM,10道题(本来还有2道被删了),9道都来自BZOJ,中间我做过2道.那么说,今天Solv.便大大增多了(但还是不如强大的Amphetamine). 题单及一句话题解如下 ...

  2. HDU 3月ACM模拟赛T10 COUNT

    题面 //来自TKJ的友好提供 ^_^ 然后我又被卡了半天不知道怎么转移N3 于是听CWY给我讲 终于会了 (虽然他讲的不是很清楚QAQ 但是凭着我们之间根本不存在的默契竟然达成了心智联通) 重点在于 ...

  3. 模拟赛20181016 Uva 1040 状压+搜索 2005 ACM world final problem c

    题目的隐含条件将这道题指向了最小生成树: 利用类似prim的方法,枚举所有子图并判断是否包含询问点,如果包含那么可以更新答案: 边统计边更新,且由于更新一定是向更多的点状态下更新,所以一定可以统计到答 ...

  4. 第九届蓝桥杯国赛+第二天的第11届acm省赛的总结

    第九届蓝桥杯国赛+第二天的第11届acm省赛的总结 25号坐的去北京的火车,10个小时的火车,然后挤了快两个小时的地铁,最终达到了中国矿业大学旁边的订的房间.12个小时很难受,晕车症状有点严重,吃了快 ...

  5. NOIP模拟赛20161022

    NOIP模拟赛2016-10-22 题目名 东风谷早苗 西行寺幽幽子 琪露诺 上白泽慧音 源文件 robot.cpp/c/pas spring.cpp/c/pas iceroad.cpp/c/pas ...

  6. 第六届acm省赛总结(退役贴)

    前言: 这是我的退役贴,之前发到了空间里,突然想到也要在博客里发一篇,虽然我很弱,但是要离开了还是有些感触,写出来和大家分享一下,希望不要见笑.回来看看,这里也好久没有更新了,这一年确实有些懈怠,解题 ...

  7. NOI模拟赛 Day1

    [考完试不想说话系列] 他们都会做呢QAQ 我毛线也不会呢QAQ 悲伤ING 考试问题: 1.感觉不是很清醒,有点困╯﹏╰ 2.为啥总不按照计划来!!! 3.脑洞在哪里 4.把模拟赛当作真正的比赛,紧 ...

  8. NOIP第7场模拟赛题解

    NOIP模拟赛第7场题解: 题解见:http://www.cqoi.net:2012/JudgeOnline/problemset.php?page=13 题号为2221-2224. 1.car 边界 ...

  9. contesthunter暑假NOIP模拟赛第一场题解

    contesthunter暑假NOIP模拟赛#1题解: 第一题:杯具大派送 水题.枚举A,B的公约数即可. #include <algorithm> #include <cmath& ...

随机推荐

  1. 50道sql练习题和答案

    最近两年的工作没有写过多少SQL,感觉水平下降十分严重,网上找了50道练习题学习和复习 原文地址:50道SQL练习题及答案与详细分析 1.0数据表介绍 --1.学生表 Student(SId,Snam ...

  2. Jquery插件的使用及制作插件

    常用插件 插件:jquery不可能包含所有的功能,我们可以通过插件扩展jquery的功能. jQuery有着丰富的插件,使用这些插件能给jQuery提供一些额外的功能. jquery.color.js ...

  3. HTML 常用小技巧 【标题图标】【锚点】【插入音乐,视频】【滚动效果】【嵌入网页】

    一 在原页面嵌入其他页面 使用iframe框架 < iframe >------ < / iframe > <iframe  src="要放在框架里面的网址或文 ...

  4. Hibernate高效查询,只查询部分/指定字段

    公司使用 DetachedCriteria detachedCriteria = DetachedCriteria.forClass(PeBulletin.class); detachedCriter ...

  5. 当堆遇到STL 代码焕发光芒

    来自度娘的释义,堆的含义大概是这样的: 感性理解: 堆(英语:heap)是计算机科学中一类特殊的数据结构的统称.堆通常是一个可以被看做一棵树的数组对象.堆总是满足下列性质: 堆中某个节点的值总是不大于 ...

  6. 胡同门牌号-2015决赛Java语言A组第一题

    标题:胡同门牌号 小明家住在一条胡同里.胡同里的门牌号都是连续的正整数,由于历史原因,最小的号码并不是从1开始排的.有一天小明突然发现了有趣的事情:如果除去小明家不算,胡同里的其它门牌号加起来,刚好是 ...

  7. POJ3159(KB4-K 差分约束)

    Candies Time Limit: 1500MS   Memory Limit: 131072K Total Submissions: 33283   Accepted: 9334 Descrip ...

  8. POJ3436(KB11-A 最大流)

    ACM Computer Factory Time Limit: 1000MS   Memory Limit: 65536K Total Submissions: 8133   Accepted: 2 ...

  9. thinkphp5+qrcode生成二维码

    1.下载二维码插件Phpqrcode,地址 https://sourceforge.net/projects/phpqrcode/files/,把下载的文件夹放到\thinkphp\vendor下 2 ...

  10. 01-01基于SHELL的数据分析

    #!/usr/bin/env bash for year in /root/Downloads/data/all/* do echo -ne `basename $year .gz`"\t& ...