[考试反思]1109csp-s模拟测试106:撞词
(撞哈希了用了模拟测试28的词,所以这次就叫撞词吧)
蓝色的0。。。
蓝色的0。。。
都该联赛了还能CE呢。。。
考试结束前15分钟左右,期望得分300
然后对拍发现T2伪了写了一个能拿90分的垃圾随机化
然后很着急,想再写一个部分分,结果没编译就交了。。。
不管在多么紧急的情况下,都要检查,编译。
。。。还不如不对拍拿一个伪的20。。。
然后T3少考虑一种情况。挂了。
T1:合并集合merge
区间dp板子。
#include<cstdio>
#include<bitset>
#include<iostream>
using namespace std;
bitset<>B[][];
int n,x[],dp[][],sz[][],ans;
int main(){
freopen("merge.in","r",stdin);freopen("merge.out","w",stdout);
scanf("%d",&n);
for(int i=;i<=n;++i)scanf("%d",&x[i]),x[i+n]=x[i];
for(int l=;l<=n<<;++l){
B[l][l][x[l]]=;
for(int r=l+;r<l+n&&r<=n<<;++r)B[l][r]=B[l][r-],B[l][r][x[r]]=;
}
for(int l=;l<=n<<;++l)for(int r=l;r<l+n&&r<=n<<;++r)sz[l][r]=B[l][r].count();
#define r l+len-1
for(int len=;len<=n;++len)for(int l=;r<=n<<;++l)for(int m=l;m<r;++m)
dp[l][r]=max(dp[l][r],dp[l][m]+dp[m+][r]+sz[l][m]*sz[m+][r]);
for(int i=;i<=n;++i)ans=max(ans,dp[i][i+n-]);
printf("%d\n",ans);
}
T2:爬climb
除了最后一步以外,每一步一定用A-B最大的。
枚举用的最后一个,考虑如何$O(logn)$进行$check$
发现其实只是i后面的药丸后错了一位,也可以理解为水位在i以后晚了一天才上涨。
预处理错位前后的两个$\sum A-B$与水位的差值,$ST$查询。
复杂度$O(nlogn)$
#include<cstdio>
#include<algorithm>
using namespace std;
struct P{
int a,b;
friend bool operator<(P x,P y){
return x.a-x.b>y.a-y.b;
}
}p[];
int hb[],ans,n,lim;
long long L,sum[],h1[],h2[],wt[],st1[][],st2[][];
long long mn1(int l,int r){
if(r<l)return ;
int B=hb[r-l+];
return min(st1[B][l],st1[B][r-(<<B)+]);
}
long long mn2(int l,int r){
if(r<l)return ;
int B=hb[r-l+];
return min(st2[B][l],st2[B][r-(<<B)+]);
}
int main(){freopen("climb.in","r",stdin);freopen("climb.out","w",stdout);
scanf("%d%lld",&n,&L);ans=lim=n+;//printf("n=")
for(int i=;i<=n;++i)scanf("%d%d",&p[i].a,&p[i].b);
sort(p+,p++n);
for(int i=;i<=n;++i)scanf("%lld",&wt[i]),wt[i]+=wt[i-];
for(int i=;i<=n;++i)sum[i]=sum[i-]+p[i].a-p[i].b;//,printf("%lld\n",sum[i]);
for(int i=;i<=n;++i)if(sum[i]<sum[i-]){lim=i;break;}
for(int i=;i<=n;++i)h1[i]=h2[i]=sum[i];
for(int i=;i<=n;++i)h1[i]-=wt[i],h2[i]-=wt[i-];
for(int i=;i<=n;++i)st1[][i]=h1[i],st2[][i]=h2[i];
for(int j=;j<;++j)for(int i=;i+(<<j)-<=n;++i)st1[j][i]=min(st1[j-][i],st1[j-][i+(<<j-)]);
for(int j=;j<;++j)for(int i=;i+(<<j)-<=n;++i)st2[j][i]=min(st2[j-][i],st2[j-][i+(<<j-)]);
for(int i=;i<=;++i)for(int j=<<i;j<<<i+&&j<=n;++j)hb[j]=i;
for(int i=;i<=n;++i){//printf("%d/%d:%d %d\n",i,n,p[i].a,p[i].b);
int out1=lower_bound(sum,sum+lim,L-p[i].a)-sum,out2=lower_bound(sum,sum+lim,L-p[i].b)-sum;//printf("%d %d %d\n",out1,out2,lim);
if(out1==lim&&out2==lim)continue;
if(out1<i&&out1!=lim){//printf("%lld\n",mn1(1,out));
if(mn1(,out1)<=)continue;
ans=min(ans,out1+);//printf("1:%d %d\n",i,out1);
}else if(out2>=i&&out2!=lim){//printf("%lld %lld\n",mn1(1,i-1),mn2(i+1,out));
if(mn1(,i-)<=)continue;
if(mn2(i+,out2)<=p[i].a-p[i].b)continue;
ans=min(ans,out2);//printf("2:%d %d\n",i,out2);
}
}printf("%d\n",ans==n+?-:ans);//printf("%lld %lld\n",mn1(1,5),mn2(7,8));
}
T3:硬币coin
简单的博弈论。主要不在博弈论,而在转化为图论。
类似2-SAT的思想(但其实并没什么关系),把每一个行列都拆成2个点,分别表示选与不选。
连边表示如果存在状态A,那么状态B一定存在。
根据每一个硬币,如果它是正面,那么如果选这一行那么就必须选这一列,如果不选这一行就不能选这一列。
双向边$A_1 - B_1$与$A_0 - B_0$。
如果硬币是反面,那么就是$A_1 - B_0$与$A_0 - B_1$
连边之后图会成为若干个联通块,互不干扰。
现在的问题就是确定每一个联通块的状态。
如果一个联通块内部矛盾(既要选又要不选)那么答案直接根据奇偶判断01。
否则,如果一个联通块内不管怎么确定状态,需要选的行列都是偶数(简称偶偶),那么对答案没有影响。
如果存在奇偶块,那么拿到最后一个奇偶块的是必胜的(你可以通过这一块决定全局的步数是奇数还是偶数)
如果没有奇偶块,那么如果奇奇块的数量是奇数,那么先手必胜3。否则2。
接下来就考虑如何争夺奇偶块。因为拿到最后一个奇偶块就赢了,所以两个人都不希望拿到倒数第二个奇偶块,那么就想拿到倒数第三个。
同理推下去,如果奇偶块一共有奇数个,那么先手者一定能拿到最后一个奇偶块,输出3。
否则,奇偶块一共有偶数个,那么先手者会尽量避免拿到第一个奇偶块。
所以为了不拿第一个奇偶块,他会去拿奇奇块。(拿偶偶块没有影响)
拿完奇奇块之后就轮到对手了,对手也同理不想拿奇偶,所以他也会拿奇奇。
所以两个人现在开始抢奇奇块了。
如果奇奇块有奇数个,那么先手者就能强制后手者拿走第一个奇偶块,就可以取胜,3。否则就是2。
所有情况讨论完毕。
#include<cstdio>
int fir[],l[],to[],ec=,pc=,ord[][],ok=,al[],sz,cnt,blcnt,sz2,g,sg;
char s[][];
void link(int a,int b){l[++ec]=fir[a];fir[a]=ec;to[ec]=b;}
void Link(int a,int b){link(a,b);link(b,a);}
void dfs(int p){
al[p]=;sz++;sz2+=p&;
for(int i=fir[p];i;i=l[i])if(al[to[i]]==)dfs(to[i]);
}
int main(){
freopen("coin.in","r",stdin);freopen("coin.out","w",stdout);
int t,n,m;
scanf("%d",&t);
while(t--){
scanf("%d%d",&n,&m);
for(int i=;i<=n;++i)scanf("%s",s[i]+);
for(int i=;i<=n;++i)pc+=,ord[][i]=pc;
for(int i=;i<=m;++i)pc+=,ord[][i]=pc;
for(int i=;i<=n;++i)for(int j=;j<=m;++j)
if(s[i][j]=='o')Link(ord[][i],ord[][j]),Link(ord[][i]^,ord[][j]^);
else if(s[i][j]=='x')Link(ord[][i],ord[][j]^),Link(ord[][i]^,ord[][j]);
for(int i=;i<=pc;++i)if(al[i]==&&al[i^]==){
sz2=sz=,dfs(i),cnt+=sz&,blcnt++,g+=(sz2&)&(sz-sz2&);
if((sz2&)&&(sz-sz2&))sg^=;
if(sz&)sg^=;
}
for(int i=;i<=pc;++i)if(al[i]&&al[i^])ok=;
if(ok)puts(sg?"":"");
else puts(m+n&?"":"");
for(int i=;i<=pc;++i)fir[i]=al[i]=;pc=ec=ok=;cnt=blcnt=g=sg=;
}
}
从博弈论的角度出发如何解释?
mex函数:mex(X)=X中不存在的最小非负整数。如mex(1,2)=0,mex(0)=1...
SG函数:为0时代表必败局面,否则为必胜局面。计算方法为mex(通向的所有状态)
整场游戏如果可以分成若干不相关的部分,那么整场游戏的SG函数值就是每个子游戏的SG函数值异或和。
在这道题里,子游戏就是一个联通块。
对于偶偶块,不论怎么选先手都会输,走一步后剩奇数步,那么SG(next)=1,SG=mex(SG(next))=0。
对于奇奇块,不论怎么选先手都会赢,走一步后剩偶数步,那么SG(next)=0,SG=mex(SG(next))=1。
对于奇偶块,先手走一步之后,剩余奇偶步都有可能,那么SG(next)={1,0},SG=mex(SG(next))=2。
计算出每一个联通块的SG函数,异或一下,ans=2+(SG?1:0)
当然,如果不存在所有硬币都正面朝上的情况,还是要特判的。
[考试反思]1109csp-s模拟测试106:撞词的更多相关文章
- [考试反思]0718 NOIP模拟测试5
最后一个是我...rank#11 rank#1和rank#2被外校大佬包揽了. 啊...考的太烂说话底气不足... 我考场上在干些什么啊!!! 20分钟“切”掉T2,又27分钟“切”掉T1 切什么切, ...
- [考试反思]0814NOIP模拟测试21
前两名是外校的240.220.kx和skyh拿到了190的[暴力打满]的好成绩. 我第5是170分,然而160分就是第19了. 在前一晚上刚刚爆炸完毕后,心态格外平稳. 想想前一天晚上的挣扎: 啊啊啊 ...
- [考试反思]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. 都不用粘人名就知道我是哪一个吧... 因为图片不能太长,所以就不 ...
- [考试反思]0725NOIP模拟测试8
看清你是个什么东西了么? 现在看清了么?rank#15?垃圾玩意? 你什么也不是.你没有骄傲,偷懒的资格! 节节败退,永无止境,你想掉到什么样子? 你还在为了成功拿到送分的T1而沾沾自喜?只不过是勉强 ...
随机推荐
- Thinkphp5.0第四篇
删除数据 当前模型删除 $user=UserModel::get(1); if($user->delete()){return '删除成功';} else{return '删除失败';} 根据主 ...
- bat脚本自动安装Jmeter&Jdk
一句话能解决的事情,绝对不要写一篇文章:一篇文章能解决的事情,绝对不要使用各种工具:一个工具能解决的事情,绝对不要跑东跑西…… 文章主要介绍脚本如何下载.安装.配置Jmeter&Jdk. 不多 ...
- 卷积神经网络CNN识别MNIST数据集
这次我们将建立一个卷积神经网络,它可以把MNIST手写字符的识别准确率提升到99%,读者可能需要一些卷积神经网络的基础知识才能更好的理解本节的内容. 程序的开头是导入TensorFlow: impor ...
- Python调用 Openstack 主要服务(keystone,nova,glance,neutron,heat)
由于Openstack更新很快,现在准备搭建基于Queen版本的Openstack,Queen版本要求keystone版本为V3,所以之前大多数接口都不能用了,百度了一下都没有比较新的实例,官方文档又 ...
- Windows中0环与3环通信(常规方式)
Windows内核分析索引目录:https://www.cnblogs.com/onetrainee/p/11675224.html 一.知识点讲解 1. 设备对象 我们在开发窗口程序的时候,消息被封 ...
- oracle查询当前用户下所有的表,包括所有的字段
oracle查询当前用户下所有的表,包括所有的字段 背景: 前两天接到一个需求,做一个展示所有表名,表备注,表数据,表字段数,点击查看按钮查看字段名和注释,支持导出. 在Oracle中,可用使用视 ...
- 2018 php 面试
排序算法 快速排序 快速排序是十分常用的高效率的算法,其思想是:先选一个标尺,用它把整个队列过一遍筛选,以保证左边的元素都不大于它,其右边都不小于它 function quickSort($arr){ ...
- Bitset改进你的程序质量
1:Bitset介绍 BitSet 是用于存储二进制位和对二进制进行操作的 Java 数据结构, 此类实现了一个按需增长的位向量.位 set 的每个组件都有一个 boolean 值.用非负的整数将 B ...
- Springboot项目的jar包目录结构
上图为一个由Luyten工具反编译后的一个jar包 说明: SpringBoot提供的bootstrap的类是放到包的最外面,比如上面的org.springframework.boot.loader. ...
- ride.py打不开RF,而是打开pycharm
标题中问题的解决方式: 进入到E:\soft\Python\Python36\Scripts,选中ride.py右键-打开方式选择python即可