要打对拍。

要打对拍。

要打对拍。

要手模数据。

要手模数据。

要手模数据。

不要相信样例。

不要相信样例。

不要相信样例。

不要飘。

不要飘。

不要飘。

跟skyh学坏了。最近不打对拍。

连续十几次考试都没打对拍,都没有出锅。

但是这次就崩了。

飘了。最近是有点飘。

也算是敲响了警钟吧。

样例都是精心构造的,有的是故意让你理解错的,有的是故意让你打错的。

我的代码除了样例基本都输出No,随便手模了一组样例就挂了。

侥幸拿到了30分。虽然也没爆零,但是也足以长记性了吧。

其实是一个大小于号打反了,判断条件写错了。

要对码下的每一个字负责。

上一轮11场以rank5告终了:2330/2143/2002/1924/1895/1890/1863/1853/1796/1731/1646/1630/1619/1590/1575|机房分数线

(和谐了一句话),跟前面的三个大神和一个大脸差距极大。。。

但是上一轮总体来说,尤其到后半,还是比较稳的。

可是这一轮一开始就是严重爆炸,直接150分差敬上。。。

长记性吧,别再犯了。

T1:序列

简单的构造题。根据A*B=N的特殊数据就可以造了。

注意大小于号不要写反。

 #include<cstdio>
int main(){
int t,n,a,b;scanf("%d",&t);
while(t--){
scanf("%d%d%d",&n,&a,&b);
if(a+b->n||1ll*a*b<n){puts("No");continue;};
puts("Yes");n-=a;b--;
for(int i=;i<=a;++i)printf("%d ",n+i);
if(!b){puts("");continue;}
int sz=n/b+,tms=n%b,sz2=n/b,tms2=b-n%b;
while(tms--){n-=sz;for(int i=;i<=sz;++i)printf("%d ",n+i);}
while(tms2--){n-=sz2;for(int i=;i<=sz2;++i)printf("%d ",n+i);}
puts("");
}
}

444B

T2:购物

算是半个结论,但是稍显然。排序后考虑每个物品的一半和前面所有物品的sum的关系,看有没有断档即可。

 #include<cstdio>
#include<algorithm>
int n;long long a[],sum,l[],r[],ans;
int main(){
scanf("%d",&n);
for(int i=;i<=n;++i)scanf("%lld",&a[i]);
std::sort(a+,a++n);
for(int i=;i<=n;++i)
if((a[i]+>>)>r[i-])ans+=r[i-]-l[i-]+,sum+=a[i],l[i]=a[i]+>>,r[i]=sum;
else l[i]=l[i-],sum+=a[i],r[i]=sum;
ans+=r[n]-l[n]+;
printf("%lld\n",ans-);
}

386B

T3:计数

看起来很难。

前序遍历有很多性质。

(——By rvalue %%%,他讲的太好了我就不想写了)

数对的限制很难处理。怎么突破?

可以发现在前序遍历确定后,中序遍历关系所限制的,其实就是a是否在b的左子树内。

进一步说,b限制的是a的子树大小。

如果在子树内,那么限制的就是左子树大小的下界,否则限制上界。

所以设dp[i][j]表示以i为根的子树大小为j。然后就

记忆化一发即可。

(当然也可以直接dp参见LNC)

 #include<cstdio>
#include<iostream>
using namespace std;
#define mod 1000000007
int liml[],limr[],dp[][],m,n;
int sch(int ord,int sz){
if(dp[ord][sz]!=-)return dp[ord][sz];
if(!sz)return dp[ord][sz]=;
dp[ord][sz]=;
for(int k=liml[ord];k<sz&&k<=limr[ord];++k)dp[ord][sz]=(dp[ord][sz]+1ll*sch(ord+,k)*sch(ord++k,sz-k-))%mod;
return dp[ord][sz];
}
int main(){
int t,n,m,a,b;scanf("%d",&t);
while(t--){
scanf("%d%d",&n,&m);
for(int i=;i<=n+;++i)for(int j=;j<=n;++j)dp[i][j]=-;
for(int i=;i<=n;++i)liml[i]=,limr[i]=n-i+;
while(m--){
scanf("%d%d",&a,&b);
if(a>b)liml[b]=max(liml[b],a-b);else limr[a]=min(limr[a],b-a-);
}printf("%d\n",sch(,n));
}
}

[考试反思]1016csp-s模拟测试76:自知的更多相关文章

  1. [考试反思]0718 NOIP模拟测试5

    最后一个是我...rank#11 rank#1和rank#2被外校大佬包揽了. 啊...考的太烂说话底气不足... 我考场上在干些什么啊!!! 20分钟“切”掉T2,又27分钟“切”掉T1 切什么切, ...

  2. [CSP-S模拟测试76]题解

    咕咕咕 A.序列 无解情况:$n>a*b$或$n<a+b-1$ 把序列分成B段,每段内部上升,各段分界处构成下降子序列. 实现并不是太简单,要动态地考虑一下边界什么的. #include& ...

  3. [考试反思]0814NOIP模拟测试21

    前两名是外校的240.220.kx和skyh拿到了190的[暴力打满]的好成绩. 我第5是170分,然而160分就是第19了. 在前一晚上刚刚爆炸完毕后,心态格外平稳. 想想前一天晚上的挣扎: 啊啊啊 ...

  4. [考试反思]1109csp-s模拟测试106:撞词

    (撞哈希了用了模拟测试28的词,所以这次就叫撞词吧) 蓝色的0... 蓝色的0... 都该联赛了还能CE呢... 考试结束前15分钟左右,期望得分300 然后对拍发现T2伪了写了一个能拿90分的垃圾随 ...

  5. [考试反思]0909csp-s模拟测试41:反典

    说在前面:我是反面典型!!!不要学我!!! 说在前面:向rank1某脸学习,不管是什么题都在考试反思后面稍微写一下题解. 这次是真的真的运气好... 这次知识点上还可以,但是答题策略出了问题... 幸 ...

  6. [考试反思]0729NOIP模拟测试10

    安度因:哇哦. 安度因:谢谢你. 第三个rank1不知为什么就来了.迷之二连?也不知道哪里来的rp 连续两次考试数学都占了比较大的比重,所以我非常幸运的得以发挥我的优势(也许是优势吧,反正数学里基本没 ...

  7. [考试反思]0714/0716,NOIP模拟测试3/4

    这几天时间比较紧啊(其实只是我效率有点低我在考虑要不要坐到后面去吹空调) 但是不管怎么说,考试反思还是要写的吧. 第三次考试反思没写总感觉缺了点什么,但是题都刷不完... 一进图论看他们刷题好快啊为什 ...

  8. [考试反思]1003csp-s模拟测试58:沉淀

    稳住阵脚. 还可以. 至少想拿到的分都拿到了,最后一题的确因为不会按秩合并和线段树分治而想不出来. 对拍了,暴力都拍了.挺稳的. 但是其实也有波折,险些被卡内存. 如果内存使用不连续或申请的内存全部使 ...

  9. [考试反思]0816NOIP模拟测试23

    210 210 210 170 还可以.暴力打满就rk4了? 但不管怎么说,总算是在改完题之后理直气壮的写考试反思了. T1是个dp,说水也不太水.(当然某脸只要A掉了一道题就要说那是水题) 我的思路 ...

随机推荐

  1. GIT原理介绍

    Git 是一套内容寻址文件系统.很不错.不过这是什么意思呢? 这种说法的意思是,Git 从核心上来看不过是简单地存储键值对(key-value).它允许插入任意类型的内容,并会返回一个键值,通过该键值 ...

  2. 【JavaScript】使用纯JS实现多张图片的懒加载(附源码)

    一.效果图如下 上面的效果图,效果需求如下 1.还没加载图片的时候,默认显示加载图片背景图 2.刚开始进入页面,自动加载第一屏幕的图片 3.下拉界面,当一张图片容器完全显露出屏幕,即刻加载图片,替换背 ...

  3. pycharm 2019/10 激活码 最新福利 (1)

    MTW881U3Z5-eyJsaWNlbnNlSWQiOiJNVFc4ODFVM1o1IiwibGljZW5zZWVOYW1lIjoiTnNzIEltIiwiYXNzaWduZWVOYW1lIjoiI ...

  4. Node.js入门教程 第三篇 (模块及路由)

    Node.js的模块 Node.js的模块与传统面向对象的类(class)不完全相同.Node.js认为文件即模块,即一个文件是一个模块.单一文件一般只专注做一件事情,保证了代码的简洁性. 创建模块: ...

  5. Ubuntu安装Chrome浏览器及解决启动no-sandbox问题

    1.安装浏览器 # apt-get install gonme # apt-get update # apt-get install google-chrome-stable 2.启动Chrome浏览 ...

  6. 深入理解Netty框架

    前言 本文讨论的主题是Netty框架,本着3W原则 (What 是什么?->Why 为什么?->How 如何做?)来一步步探究Netty原理和本质以及运用场景. 了解基本名词 1.BIO. ...

  7. BBEdit 13.0 for Mac 打开大文件不吃力

    BBEdit 是一款拥有 16 年历史的 HTML 和文本编辑器,拥有高性能且流畅的文本处理能力,适用于 Web 和软件开发者,具备功能丰富且强大的智能搜索.代码折叠.FTP 和 SFTP 管理等功能 ...

  8. hydra暴力破解

    hydra,是一个非常好用的暴力破解工具,而且名字也很cool. 下面是官网上的介绍: AFP, Cisco AAA, Cisco auth, Cisco enable, CVS, Firebird, ...

  9. 权限维持-wmi事件

    0x01 前言 WMIC扩展WMI(Windows Management Instrumentation,Windows管理工具),提供了从命令行接口和批命令脚本执行系统管理的支持. 在2015年的b ...

  10. [Luogu3659][USACO17FEB]Why Did the Cow Cross the Road I G

    题目描述 Why did the cow cross the road? Well, one reason is that Farmer John's farm simply has a lot of ...