NOIP2016 模拟赛
——那些年,我们学过的文化课
背单词
(word.c/cpp/pas)
【题目描述】
fqk 退役后开始补习文化课啦, 于是他打开了英语必修一开始背单
词。 看着满篇的单词非常头疼, 而每次按照相同的顺序背效果并不好,
于是 fqk 想了一种背单词的好方法!他把单词抄写到一个 n 行 m 列的
表格里,然后每天背一行或者背一列。他的复习计划一共有 k 天,在
k 天后, fqk 想知道,这个表格中的每个单词,最后一次背是在哪一
天呢?
【输入格式】
第一行三个整数 k m n , , 。
接下来 k 行,每行的格式可能如下:
1. r ,表示当前天 fqk 背了第 r 行的单词。
. 2 c ,表示当前天 fqk 背了第 c 列的单词。
【输出格式】
输出包含 n 行, 每行 m 个整数, 表示每个格子中的单词最后一次背
是在哪天,如果这个单词没有背过,则输出 0 。
【输入样例】
3 3 3
1 2
2 3
1 3
【输出样例】
0 0 2
1 1 2
3 3 3
【数据范围】
对于 % 30 的数据, 1000 , ,  k m n 。
对于 % 100 的数据, 100000 , 100000 , 5000 ,     k m n m n 。
【时空限制】
对于每个测试点,时间限制为 s 1 ,空间限制为 MB 512 。

模拟

#include<cstdio>
#define maxn 5010
using namespace std;
int n,m,k,mxc[maxn],mxl[maxn];
int init(){
int x=,f=;char s=getchar();
while(s<''||s>''){if(s=='-')f=-;s=getchar();}
while(s>=''&&s<=''){x=x*+s-'';s=getchar();}
return x*f;
}
int Max(int x,int y){
return x>y?x:y;
}
int main(){
freopen("word.in","r",stdin);
freopen("word.out","w",stdout);
n=init();m=init();k=init();
int x,y;
for(int i=;i<=k;i++){
x=init();y=init();
if(x==)mxc[y]=i;
if(x==)mxl[y]=i;
}
for(int i=;i<=n;i++){
for(int j=;j<=m;j++)
printf("%d ",Max(mxc[i],mxl[j]));
printf("\n");
}
fclose(stdin);fclose(stdout);
return ;
}

脱水缩合
(merge.c/cpp/pas)
【题目描述】
fqk 退役后开始补习文化课啦, 于是他打开了生物必修一开始复习
蛋白质,他回想起了氨基酸通过脱水缩合生成肽键,具体来说,一个
氨基和一个羧基会脱去一个水变成一个肽键。于是他脑洞大开,给你
出了这样一道题:
fqk 将给你 6 种氨基酸和 m 个脱水缩合的规则,氨基酸用
' ' , ' ' , ' ' , ' ' , ' ' , ' ' f e d c b a 表示,每个规则将给出两个字符串 t s, ,其中
1 | | , 2 | |   t s ,表示 s 代表的两个氨基酸可以通过脱水缩合变成 t 。然后
请你构建一个长度为 n ,且仅由 ' ' , ' ' , ' ' , ' ' , ' ' , ' ' f e d c b a 构成的氨基酸序列,
如果这个序列的前两个氨基酸可以进行任意一种脱水缩合, 那么就可
以脱水缩合,脱水缩合后序列的长度将 1  ,这样如果可以进行 1  n 次
脱水缩合,最终序列的长度将变为 1 ,我们可以认为这是一个蛋白质,
如果最后的蛋白质为 ' 'a , 那么初始的序列就被称为一个好的氨基酸序
列。 fqk 想让你求出有多少好的氨基酸序列。
注:题目描述可能与生物学知识有部分偏差(即氨基酸进行脱水
缩合后应该是肽链而不是新的氨基酸),请以题目描述为准。
【输入格式】
第一行两个整数 q n, 。
接下来 q 行,每行两个字符串 t s, ,表示一个脱水缩合的规则。
【输出格式】
一行,一个整数表示有多少好的氨基酸序列。
【输入样例】
3 5
ab a
cc c
ca a
ee c
ff d
【输出样例】
4
【样例解释】
一共有四种好的氨基酸序列,其脱水缩合过程如下:
"abb" "ab" "a"
"cab" "ab" "a"
"cca" "ca" "a"
"eea" "ca" "a"
【数据范围】
对于 % 100 的数据, 36 , 6 2    q n 。数据存在梯度。
【时空限制】
对于每个测试点,时间限制为 s 2 ,空间限制为 MB 512 。

这题卡读题啊 无语了

#include<cstdio>
#define maxn 110
using namespace std;
int n,m,f[maxn][maxn][maxn],r[maxn],ans;
char s[],c[];
bool vis[];
void dfs(int now,int x,int y){
if(now==n+){
if(x!=)return;
int mx=;
for(int i=;i<=n;i++)
mx=mx*+r[i];
if(vis[mx])return;
vis[mx]=;
ans++;return;
}
for(int i=;i<=;i++)
if(f[x][y][i])dfs(now+,i,r[now+]);
}
void Dfs(int now){
if(now==n+){
dfs(,r[],r[]);return;
}
for(int i=;i<=;i++){
r[now]=i;Dfs(now+);r[now]=;
}
}
int main()
{
freopen("merge.in","r",stdin);
freopen("merge.out","w",stdout);
scanf("%d%d",&n,&m);
for(int i=;i<=m;i++){
scanf("%s%s",s,c);
int x=s[]-'a'+,y=s[]-'a'+,z=c[]-'a'+;
f[x][y][z]=;
}
Dfs();printf("%d\n",ans);
fclose(stdin);fclose(stdout);
return ;
}

一次函数
(fx.c/cpp/pas)
【题目描述】
fqk 退役后开始补习文化课啦, 于是他打开了数学必修一开始复习
函数, 他回想起了一次函数都是 b kx x f   ) ( 的形式, 现在他给了你 n 个
一次函数
i i i
b x k x f   ) ( , 然后将给你 m 个操作, 操作将以如下格式给出:
M . 1 i k b ,把第 i 个函数改为 b kx x f i   ) ( 。
Q . 2 l r x ,询问 ))) ( (... (
1
x f f f
l r r 
mod 1000000007 的值。
【输入格式】
第一行两个整数 n , m ,代表一次函数的数量和操作的数量。
接下来 n 行,每行两个整数,表示
i
k ,
i
b 。
接下来 m 行,每行的格式为 M i k b 或 Q l r x 。
【输出格式】
对于每个操作 Q ,输出一行表示答案。
【输入样例】
5 5
4 2
3 6
5 7
2 6
7 5
Q 1 5 1
Q 3 3 2
M 3 10 6
Q 1 4 3
Q 3 4 4
【输出样例】
1825
17
978
98
【数据范围】
对于 % 30 的数据, 1000 ,  m n 。
对于 % 100 的数据, 1000000007 , , , 200000 ,   x b k m n 。
【时空限制】
对于每个测试点,时间限制为 s 2 ,空间限制为 MB 512 。

暴力不粘了

线段树

/*线段树 每个节点维护 k b 合并的时候手推一下式子就好了 跑的略慢 */
#include<cstdio>
#define mod 1000000007
#define ll long long
#define lc k*2
#define rc k*2+1
#define mid (l+r)/2
#define maxn 200010
#ifdef unix
#define LL "%lld\n"
#else
#define LL "%I64d\n"
#endif
using namespace std;
int n,m;
ll A[maxn*],B[maxn*];
char s[];
int init(){
int x=,f=;char s=getchar();
while(s<''||s>''){if(s=='-')f=-;s=getchar();}
while(s>=''&&s<=''){x=x*+s-'';s=getchar();}
return x*f;
}
void Insert(int k,int l,int r,int x,int a,int b){
if(l==r){
A[k]=a;B[k]=b;return;
}
if(x<=mid)Insert(lc,l,mid,x,a,b);
else Insert(rc,mid+,r,x,a,b);
A[k]=A[lc]*A[rc]%mod;B[k]=(A[rc]*B[lc]%mod+B[rc])%mod;
}
ll Queryk(int k,int l,int r,int x,int y){
if(x<=l&&y>=r)return A[k];
if(y<=mid)return Queryk(lc,l,mid,x,y);
else if(x>mid)return Queryk(rc,mid+,r,x,y);
else{
ll kl=Queryk(lc,l,mid,x,y);
ll kr=Queryk(rc,mid+,r,x,y);
return kl*kr%mod;
}
}
ll Queryb(int k,int l,int r,int x,int y){
if(x<=l&&y>=r)return B[k];
if(y<=mid)return Queryb(lc,l,mid,x,y);
else if(x>mid)return Queryb(rc,mid+,r,x,y);
else{
ll bl=Queryb(lc,l,mid,x,y);
ll br=Queryb(rc,mid+,r,x,y);
ll kr=Queryk(rc,mid+,r,x,y);
return (kr*bl%mod+br)%mod;
}
}
int main()
{
freopen("fx.in","r",stdin);
freopen("fx.out","w",stdout);
n=init();m=init();ll x,y,z;
for(int i=;i<=n;i++){
x=init();y=init();
Insert(,,n,i,x,y);
}
for(int i=;i<=m;i++){
scanf("%s",s);x=init();y=init();z=init();
if(s[]=='M')Insert(,,n,x,y,z);
else if(s[]=='Q'){
ll K=Queryk(,,n,x,y);
ll BB=Queryb(,,n,x,y);
printf(LL,(K*z%mod+BB)%mod);
}
}
fclose(stdin);fclose(stdout);
return ;
}

11.9 noip模拟试题的更多相关文章

  1. 11.14 noip模拟试题

      题目名称 正确答案 序列问题 长途旅行 英文名称 answer sequence travel 输入文件名 answer.in sequence.in travel.in 输出文件名 answer ...

  2. 11.13 noip模拟试题

    题目名称 笔记 括号 城堡可执行文件名 note brackets castle输入文件名 note.in brackets.in castle.in输出文件名 note.in brackets.ou ...

  3. 11.12 noip模拟试题

    题目名称 加密 冒泡排序图 重建可执行文件名 encrypt bubble rebuild输入文件名 encrypt.in bubble.in rebuild.in输出文件名 encrypt.in b ...

  4. 11.10 noip模拟试题

    1.第K小数 (number.cpp/c/pas) [问题描述] 有两个正整数数列,元素个数分别为N和M.从两个数列中分别任取一个数 相乘,这样一共可以得到N*M个数,询问这N*M个数中第K小数是多少 ...

  5. 11.7 NOIP模拟赛

    目录 2018.11.7 NOIP模拟 A 序列sequence(two pointers) B 锁lock(思路) C 正方形square(埃氏筛) 考试代码 B C 2018.11.7 NOIP模 ...

  6. 11/1 NOIP 模拟赛

    11.1 NOIP 模拟赛 期望得分:50:实际得分:50: 思路:暴力枚举 + 快速幂 #include <algorithm> #include <cstring> #in ...

  7. 10.11 noip模拟试题

    4题均为128M,1s 1. 锻炼计划(exercise.pas) 身体是革命的本钱,OIers不要因为紧张的学习和整天在电脑前而忽视了健康问题.小x设计了自己的锻炼计划,但他不知道这个计划是否可行, ...

  8. 10.27 noip模拟试题

    1.铺瓷砖(tile.cpp/c/pas)[问题描述]有一面很长很长的墙. 你需要在这面墙上贴上两行瓷砖. 你的手头有两种不同尺寸的瓷砖,你希望用这两种瓷砖各贴一行.瓷砖的长可以用分数表示,贴在第一行 ...

  9. 10.26 noip模拟试题

    enc[问题背景]zhx 和他的妹子聊天.[问题描述]考虑一种简单的加密算法.假定所有句子都由小写英文字母构成,对于每一个字母,我们将它唯一地映射到另一个字母.例如考虑映射规则:a->b, b- ...

随机推荐

  1. Qt源码分析之QPointer

    QPointer是一个指针封装类,其作用类似于智能指针,但是它最大的特点应该是在指针的控制上,它希望一个Qt的指针(当然是从QObject派生的)可以同时被多个类拥有,这在界面编程中当然是很常见的事情 ...

  2. 剖析Qt的事件机制原理

    版权声明 请尊重原创作品.转载请保持文章完整性,并以超链接形式注明原始作者“tingsking18”和主站点地址,方便其他朋友提问和指正. QT源码解析(一) QT创建窗口程序.消息循环和WinMai ...

  3. RubyGems使用

    RubyGems的功能类似于Linux下的apt-get.使用它可以方便第从远程服务器下载并安装Rails. # 安装指定gem包,程序先从本机查找gem包并安装,如果本地没有,则从远程gem安装.g ...

  4. linux使用man命令后退出

    linux使用man命令后 使用q退出

  5. 利用if else 求已发奖金总数

    class Program    {        static void Main(string[] args)        {            while (true)           ...

  6. 尚未在 Web 服务器上注册 ASP.NET 4.0” 的解决办法

    http://www.sowsoy.com/topics-537.html win7,vs2010创建.NetFramework 4框架下的Asp.Net空网站.系统提示 “尚未在 Web 服务器上注 ...

  7. ☀【JS】有效状态机

    JavaScript与有限状态机http://www.ruanyifeng.com/blog/2013/09/finite-state_machine_for_javascript.html

  8. devpress GridControl控件绑定RepositoryItemImageComboBox 作为下拉框使用 zt

    1.拖出gridview控件,然后将字段绑定上去 2.将要做下拉框的控件加入RepositoryItemImageComboBox控件 3.绑定数据 ; i < ; i++) { //如果取值时 ...

  9. selenium webdriver(2)---页面对象定位

    webdriver的元素定位很灵活,提供了多种定位方式: Id LinkText PartialLinkText Name TagName Xpath ClassName CssSelector 这些 ...

  10. codeforces Codeforces 650A Watchmen

    题意:两点(x1,y1), (x2,y2)的曼哈顿距离=欧几里得距离 也就是:x1=x2或y1=y2,再删除重合点造成的重复计数即可. #include <stdio.h> #includ ...