[考试反思]1113csp-s模拟测试114:一梦
自闭。不废话。写一下低错。
T1:觉得信心赛T1不会很恶心一遍过样例直接没对拍(其实是想写完T2之后回来对拍的)
状态也不好,基本全机房都开始码了我还没想出来(skyh已经开T2了)。想了40多分钟。
区别不大。真是人才。
而且反向的单调栈没reverse。爆零。
T2:100多分钟打表找到了一个仅适用于n,a<=5的规律(我还以为它是普适的,但其实n<=5,a<=5也不完全对)。浪费时间太多。
这次说实在的不是故意刚它的,因为打表不断有新进展所以很开心就没看时间。
T3:最后7分钟写的暴力得了和前198分钟一样的分数。
丢30分。求lca都不会打了。
真他妈难度中等有区分度看来我女队也混不了了2333。。。
把出题人挂起来婊
对自己没话可说了。那就干脆别废话了吧。
T1:A
可以发现,他给的二次函数没有c。有什么特性?一定经过原点?这个没什么用。
是可以整体除以x得到一次函数,正负分情况讨论。那么就剩下一个单调栈维护凸包板子。
写了对拍20分钟肯定是能调出来的。
- #include<cstdio>
- #include<algorithm>
- using namespace std;
- #define int long long
- struct line{
- int k,b;
- friend bool operator<(line A,line B){
- return A.k<B.k||(A.k==B.k&&A.b<B.b);
- }
- }l[];
- int ans[],sta[],top,negans[];
- int cal(int o,int x){return l[o].k*x*x+l[o].b*x;}
- long double mp(int o,int p){return (.0L+l[o].b-l[p].b)/(l[p].k-l[o].k);}
- main(){
- freopen("A.in","r",stdin);freopen("A.out","w",stdout);
- int n,q,x;scanf("%lld%lld",&n,&q);
- for(int i=;i<=n;++i)scanf("%lld%lld",&l[i].k,&l[i].b);
- sort(l+,l++n);
- for(int i=;i<=n;++i){
- while(top&&l[sta[top]].k==l[i].k&&l[sta[top]].b<l[i].b)top--;
- while(top&&mp(sta[top],i)<)top--;
- while(top>&&mp(sta[top-],sta[top])>=mp(sta[top-],i))top--;
- sta[++top]=i;
- }//for(int i=1;i<=top;++i)printf("%lld %lld\n",l[sta[i]].k,l[sta[i]].b);printf("%lld\n",l[2].k-l[3].k);
- int ptr=;
- for(int X=;X<;++X){
- while(ptr<top&&cal(sta[ptr],X)<=cal(sta[ptr+],X))ptr++;
- ans[X]=cal(sta[ptr],X);
- }
- top=;ptr=;
- for(int i=n;i;--i){
- while(top&&l[sta[top]].k==l[i].k&&l[sta[top]].b>l[i].b)top--;
- while(top>&&mp(sta[top-],sta[top])>=mp(sta[top-],i))top--;
- sta[++top]=i;
- }reverse(sta+,sta++top);
- for(int X=-;X>-;--X){
- while(ptr<top&&cal(sta[ptr],X)<=cal(sta[ptr+],X))ptr++;
- negans[-X]=cal(sta[ptr],X);
- }
- while(q--)scanf("%lld",&x),printf("%lld\n",x>=?ans[x]:negans[-x]);
- }
T2:B
除了第一个以外,其余的每一位是不互相影响的。
那么答案就是$a_1 + \sum\limits_{i=2)^{n} f(a_1,a_i) $
关键在于计算$f$函数。可以发现这个$f$函数的含义:
第一个物品被选完了,第二个物品期望被选多少个。
枚举它选了多少个,计算出概率,特殊处理被选完的情况,概率就是1-前面没被选的概率之和。
$f(a,b)=\sum\limits_{i=0}^{b-1} \frac{i \times C_{a+i-1}^{i}}{2^{a+i}} \ + b \ - \sum\limits_{i=0}^{b-1}\frac{b \times C_{a+i-1}^{i}}{2^{a+i}}$
+b前面的部分就是没选完,后面的部分就是选完了的剩余情况。组合数就是枚举这么多次选择恰好把它选完的方案数,除总方案数就是概率。
要-1的原因是最后一步要默认选择的是a而不是b。否则会重复计数。
再看本题的特殊之处,每次调用$f$函数的时候,第一个参数$a$都是一致的。
那么只要处理出来a这一列就好了。
可以发现,b每增大1,式子的变化之处并不多,前后的和式都多了一项。线性递推预处理即可。
- #include<cstdio>
- #include<iostream>
- using namespace std;
- #define int long long
- #define mod 323232323
- #define S 1000005
- int qpow(int b,int t,int a=){for(;t;t>>=,b=b*b%mod)if(t&)a=a*b%mod;return a;}
- int fac[S],inv[S],pw[S],ipw[S],F[S],G[S],ans,x;
- int C(int b,int t){return b<t?:fac[b]*inv[t]%mod*inv[b-t]%mod;}
- void f(){
- int totpos=;
- for(int i=;i<;++i){
- F[i]=((i?F[i-]:)+i*C(x-+i,i)%mod*ipw[x+i])%mod;
- totpos=(totpos+C(x-+i,i)*ipw[x+i])%mod;
- G[i]=(+i)*(+mod-totpos)%mod;
- }
- for(int i=S-;i;--i)F[i]=(F[i-]+G[i-])%mod;
- }
- main(){
- freopen("B.in","r",stdin);freopen("B.out","w",stdout);
- fac[]=;
- for(int i=;i<S;++i)fac[i]=fac[i-]*i%mod;
- inv[S-]=qpow(fac[S-],mod-);
- for(int i=S-;~i;--i)inv[i]=inv[i+]*(i+)%mod;
- pw[]=;
- for(int i=;i<S;++i)pw[i]=pw[i-]*%mod;
- ipw[S-]=qpow(pw[S-],mod-);
- for(int i=S-;~i;--i)ipw[i]=ipw[i+]*%mod;
- int n,y;scanf("%lld%lld",&n,&x);n--;ans=x;f();
- while(n--)scanf("%lld",&y),ans=(ans+F[y])%mod;
- printf("%lld\n",ans);
- }
T3:C
不想写。细节多,题解还那么垃圾。
$O(n\ log \ n \ log \ a_i)$的暴力看懂了。就是离线询问(否则会MLE)枚举每一位的答案贡献。
首先对于每次询问我们把或当成加法。求出路径上所有点的权值和,以及距离之和。
然后把或当成加法的多余贡献就是两个值相与的值,求出每个答案与后的值从上面那个值里扣除就是答案。
可以发现二进制串在递增序列上是有循环节的。先考虑u到lca的贡献。
处理数组dp[i][j]表示从i号节点开始的完整循环节的长度为$2^j$的祖先链上的当前处理的这一位的$a_i$值与循环节的1的撞上的数的个数。
然后对于非完整循环节特殊处理一下。我的想法是(强调:这是我自己yy的可能不对):
再处理一个数组f[i][j]表示从i号点开始的长度为$2^j$的祖先链上的当前处理的这一位的$a_i$值为1的数的个数。也就是默认了距离值的这一位是1。
因为最后剩下的一段非完整循环节一定是一堆0,后面都是1。这样的话你倍增跳一下把0的都跳过,然后剩下的1用f数组就可以计算出来。
然后u到lca这一段就处理完了。对于v到lca的这一段,我们把v往上跳直到遇到第一个完整循环节开始的地方,这个跳可以类似的预处理。
然后剩下的就和u到lca一样了。只不过一个的循环是000011110000111100...这样的,另一个是111100001111000011....这样的。
那么你只要把前几个1排除在完整循环节之外进行处理,剩下的两边就完全一样了。
大神yxs写出来了得到了T70的好成绩(从上述代码细节你就可以感受到这题常数有多大)
心累。真心不想写。就这样吧。等yxs或其他大神AC之后我再update吧
[考试反思]1113csp-s模拟测试114:一梦的更多相关文章
- [考试反思]0718 NOIP模拟测试5
最后一个是我...rank#11 rank#1和rank#2被外校大佬包揽了. 啊...考的太烂说话底气不足... 我考场上在干些什么啊!!! 20分钟“切”掉T2,又27分钟“切”掉T1 切什么切, ...
- [考试反思]0814NOIP模拟测试21
前两名是外校的240.220.kx和skyh拿到了190的[暴力打满]的好成绩. 我第5是170分,然而160分就是第19了. 在前一晚上刚刚爆炸完毕后,心态格外平稳. 想想前一天晚上的挣扎: 啊啊啊 ...
- [考试反思]1109csp-s模拟测试106:撞词
(撞哈希了用了模拟测试28的词,所以这次就叫撞词吧) 蓝色的0... 蓝色的0... 都该联赛了还能CE呢... 考试结束前15分钟左右,期望得分300 然后对拍发现T2伪了写了一个能拿90分的垃圾随 ...
- [考试反思]0909csp-s模拟测试41:反典
说在前面:我是反面典型!!!不要学我!!! 说在前面:向rank1某脸学习,不管是什么题都在考试反思后面稍微写一下题解. 这次是真的真的运气好... 这次知识点上还可以,但是答题策略出了问题... 幸 ...
- [考试反思]0729NOIP模拟测试10
安度因:哇哦. 安度因:谢谢你. 第三个rank1不知为什么就来了.迷之二连?也不知道哪里来的rp 连续两次考试数学都占了比较大的比重,所以我非常幸运的得以发挥我的优势(也许是优势吧,反正数学里基本没 ...
- [考试反思]0714/0716,NOIP模拟测试3/4
这几天时间比较紧啊(其实只是我效率有点低我在考虑要不要坐到后面去吹空调) 但是不管怎么说,考试反思还是要写的吧. 第三次考试反思没写总感觉缺了点什么,但是题都刷不完... 一进图论看他们刷题好快啊为什 ...
- [考试反思]1003csp-s模拟测试58:沉淀
稳住阵脚. 还可以. 至少想拿到的分都拿到了,最后一题的确因为不会按秩合并和线段树分治而想不出来. 对拍了,暴力都拍了.挺稳的. 但是其实也有波折,险些被卡内存. 如果内存使用不连续或申请的内存全部使 ...
- [考试反思]0816NOIP模拟测试23
210 210 210 170 还可以.暴力打满就rk4了? 但不管怎么说,总算是在改完题之后理直气壮的写考试反思了. T1是个dp,说水也不太水.(当然某脸只要A掉了一道题就要说那是水题) 我的思路 ...
- [考试反思]0801NOIP模拟测试11
8月开门红. 放假回来果然像是神志不清一样. 但还是要接受这个事实. 嗯,说好听点,并列rank#7. 说难听点,垃圾rank#18. 都不用粘人名就知道我是哪一个吧... 因为图片不能太长,所以就不 ...
随机推荐
- Robotframework常见问题收集
一.Robotframework1.7.3控制台乱码处理 1.找到文件C:\Python37\Lib\site-packages\robotide\contrib\testrunner\testrun ...
- Java类中static的用法
关于Java中static的使用有以下四种情况: 1.静态成员变量 被static修饰的成员变量,叫静态成员变量或类变量:没有被static修饰的变量,叫实例变量. 两者的区别是: ...
- autocad 二次开发 最小包围圆算法
autocad 二次开发 最小包围圆算法 主要实现了在模型空间下的得到一个包围所有图元的最小圆,该算法的思路是这样:1.从点集中随机选出两个点作为直径对圆进行初始化.2.判断下一个点p是否在圆中,如果 ...
- hdu 6298 Maximum Multiple (简单数论)
Maximum Multiple Time Limit: 4000/2000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) ...
- Python读写Excel表格(简单实用)
前言 本文的文字及图片来源于网络,仅供学习.交流使用,不具有任何商业用途,版权归原作者所有,如有问题请及时联系我们以作处理.作者:giao窝里giao首先安装两个库:pip install xlrd. ...
- SpringBoot微服务电商项目开发实战 --- Redis缓存雪崩、缓存穿透、缓存击穿防范
最近已经推出了好几篇SpringBoot+Dubbo+Redis+Kafka实现电商的文章,今天再次回到分布式微服务项目中来,在开始写今天的系列五文章之前,我先回顾下前面的内容. 系列(一):主要说了 ...
- 函数式响应式编程 - Functional Reactive Programming
我们略过概念,直接看函数式响应式编程解决了什么问题. 从下面这个例子展开: 两个密码输入框,一个提交按钮. 密码.确认密码都填写并一致,允许提交:不一致提示错误. HTML 如下: <input ...
- ASP.NET CORE 使用Consul实现服务治理与健康检查(1)——概念篇
背景 笔者所在的公司正在进行微服务改造,这其中服务治理组件是必不可少的组件之一,在一番讨论之后,最终决定放弃 Zookeeper 而采用 Consul 作为服务治理框架基础组件.主要原因是 Consu ...
- JS---DOM---案例:模拟百度搜索框
模拟百度搜索框 我的思路整理: 1. 注册文本框抬起事件(onkeyup) 2. 处理函数: --->创建临时数组,循环遍历文本框键入的文字内容和keywords数组,用keyWords[i]. ...
- 如何从Mac删除恶意广告软件,摆脱那些通过弹出广告或工具栏入侵Mac的恶意软件
厌倦了那些利用弹出式广告和工具栏之类入侵Mac的恶意软件?该如何摆脱Mac上的恶意软件呢?今天小编为大家带来两种方法从Mac 删除广告软件,甚至阻止它到达您的Mac,感兴趣的朋友一起来看看吧! 方法一 ...