2019.10.25 csp-s模拟测试86 反思总结
继续存档
早上来补了一下昨天的题,不过肯定这两天的没法完全补起来
T1:
经典思路:关于位运算的题讨论每一位的贡献
#include<iostream>
#include<cstdio>
using namespace std;
int t,mod=1e9+;;
long long l,r,all,cnt,ans;
long long count(long long x,int k){
long long num=;
num+=x/(1ll<<(k+));
x-=(1ll<<(k+))*num;
num*=(1ll<<k);
num+=((x>=(1ll<<k))?(x+-(1ll<<k)):);
return num;
}
int main()
{
scanf("%d",&t);
while(t--){
scanf("%lld%lld",&l,&r);
all=r-l+;
ans=;
for(int i=;i<=;i++){
cnt=count(r,i)-count(l-,i);
ans=(ans+cnt*(all-cnt)%mod*(1ll<<(i+))%mod)%mod;
}
printf("%lld\n",ans);
}
return ;
}
T2:
优化DP刷表可以卡过去,并不是完全的正解啦:P
(我才知道bool是1bit而int是4bits…一直以来bool都用int代替的…)
关键点:必败状态不能互相转移、打表+分析发现对于每个让二元组(x,y)必败的z,x、y所占用的数字不重复且x与y的差不重复。
题解里好像有点小锅,如果存在f(x,y)=k<i,则f(x+i-k,y)、f(x,y+i-k)、f(x+i-k,y+i-k)不可能等于i。
#include<iostream>
#include<cstdio>
#include<cstring>
using namespace std;
int t,x,y,z,maxn;
bool f[][][];
int main()
{
for(int i=;i<=;i++){
for(int j=;j<=;j++){
for(int k=;k<=;k++){
if(!f[i][j][k]){
for(int x=;x<=;x++){
maxn=;
if(x&)maxn=min(maxn,-i);
if(x&)maxn=min(maxn,-j);
if(x&)maxn=min(maxn,-k);
for(int l=;l<=maxn;l++)f[i+(x&)*l][j+((x>>)&)*l][k+((x>>)&)*l]=;
}
}
}
}
}
scanf("%d",&t);
while(t--){
scanf("%d%d%d",&x,&y,&z);
if(f[x][y][z])printf("Yes\n");
else printf("No\n");
}
return ;
}
T3:
关键点在于转化题目。也是一个经典的思路:遇到绝对值的问题,可以考虑把绝对值拆成正负两种作差方法分开考虑。
于是对于一些si,它会被加两次或者减两次。对于另一些si,它会加一次减一次正好抵消。首位特殊讨论。
设计dp,首先可以想到+2、-2、0这三种。但是考虑2和-2的产生就会发现2和-2肯定是间隔的XD!所以还要考虑它们的间隔状态是否合法。
通过把0的状态拆成2->-2、-2->2两种来保证转移合法。
#include<iostream>
#include<cstdio>
#include<cstring>
using namespace std;
int n,k;
int f[][][],a[];
int main()
{
scanf("%d%d",&n,&k);
for(int i=;i<=n;i++)scanf("%d",&a[i]);
memset(f,-0x3f,sizeof(f));
for(int i=;i<=n;i++){
for(int j=;j<=;j++){
f[i][][j]=;
}
}
for(int i=;i<=n;i++){
for(int j=;j<=min(i,k);j++){
f[i][j][]=max(f[i-][j-][],f[i-][j][])+((j==||j==k)?:)*a[i];
f[i][j][]=max(f[i-][j-][],f[i-][j][])-((j==||j==k)?:)*a[i];
f[i][j][]=max(f[i][j][],f[i-][j][]);
if(j!=&&j!=k)f[i][j][]=max(f[i][j][],f[i-][j-][]);
f[i][j][]=max(f[i][j][],f[i-][j][]);
if(j!=&&j!=k)f[i][j][]=max(f[i][j][],f[i-][j-][]);
}
}
printf("%d\n",max(f[n][k][],f[n][k][]));
return ;
}
在尝试补这套题的时候发生了各种各样脑残的错误,例如“咦bool原来是1bit吗”之类的:D
脑子是个好东西 希望我有XDDDDDDDD
2019.10.25 csp-s模拟测试86 反思总结的更多相关文章
- 2019.8.3 [HZOI]NOIP模拟测试12 C. 分组
2019.8.3 [HZOI]NOIP模拟测试12 C. 分组 全场比赛题解:https://pan.baidu.com/s/1eSAMuXk 刚看这题觉得很难,于是数据点分治 k只有1和2两种,分别 ...
- 2019.8.3 [HZOI]NOIP模拟测试12 B. 数颜色
2019.8.3 [HZOI]NOIP模拟测试12 B. 数颜色 全场比赛题解:https://pan.baidu.com/s/1eSAMuXk 数据结构学傻的做法: 对每种颜色开动态开点线段树直接维 ...
- 2019.8.3 [HZOI]NOIP模拟测试12 A. 斐波那契(fibonacci)
2019.8.3 [HZOI]NOIP模拟测试12 A. 斐波那契(fibonacci) 全场比赛题解:https://pan.baidu.com/s/1eSAMuXk 找规律 找两个节点的lca,需 ...
- csp-s模拟测试86
csp-s模拟测试86 分屋前的最后一次考试,我早就放弃了自己. 02:02:46 70 02:02:57 03:16:08 100 03:16:08 $T1$忘了按位计算,达哥按位计算的$T1$当时 ...
- 2019.8.14 NOIP模拟测试21 反思总结
模拟测试20的还没改完先咕着 各种细节问题=错失190pts T1大约三分钟搞出了式子,迅速码完,T2写了一半的时候怕最后被卡评测滚去交了,然后右端点没有初始化为n…但是这样还有80pts,而我后来还 ...
- 2019.8.9 NOIP模拟测试15 反思总结
日常爆炸,考得一次比一次差XD 可能还是被身体拖慢了学习的进度吧,虽然按理来说没有影响.大家听的我也听过,大家学的我也没有缺勤多少次. 那么果然还是能力问题吗……? 虽然不愿意承认,但显然就是这样.对 ...
- 2019.8.1 NOIP模拟测试11 反思总结
延迟了一天来补一个反思总结 急匆匆赶回来考试,我们这边大家的状态都稍微有一点差,不过最后的成绩总体来看好像还不错XD 其实这次拿分的大都是暴力[?],除了某些专注于某道题的人以及远程爆踩我们的某学车神 ...
- 2019.10.25 csp-s模拟测试87 反思总结
一次非常神奇的考试,考完试以后看着T2的0pts突然笑死我自己 太智障了这什么神奇的题意理解错误23333 T1一眼分类讨论,两眼二分,觉得分类讨论有点玄学但是出题人八成不会卡[何],然后本着对二分的 ...
- 2019/10/17 CSP模拟 总结
T1 补票 Ticket 没什么好说的,不讲了 T2 删数字 Number 很后悔的是其实考场上不仅想出了正解的方程,甚至连优化都想到了,却因为码力不足只打了\(O(n^2)\)暴力,甚至还因为细节挂 ...
随机推荐
- LUOGU P4281 [AHOI2008]紧急集合 / 聚会 (lca)
传送门 解题思路 可以通过手玩或打表发现,其实要选的点一定是他们三个两两配对后其中一对的$lca$上,那么就直接算出来所有的$lca$,比较大小就行了. #include<iostream> ...
- CSS自动换行、强制不换行、强制断行、超出显示省略号
转自:https://blog.csdn.net/liuyan19891230/article/details/50969393 P标签是默认是自动换行的,因此设置好宽度之后,能够较好的实现效果,但是 ...
- 我的服装DRP之即时通讯——为WCF增加UDP绑定(应用篇)
发个牢骚,博客园发博文竟然不能写副标题.这篇既为我的服装DRP系列第二篇,也给为WCF增加UDP绑定系列收个尾.原本我打算记录开发过程中遇到的一些问题和个人见解,不过写到一半发现要写的东西实在太多,有 ...
- Python ----键抠图
背景 这段时间,经常有人来找我,说我是学计算机的,能不能帮他p一下证件照,我只想说,MMP的,我是学计算机的不错,可我不会ps阿. 我想了一会,python 这么火,能不能来个自动抠图,说好就干吧 介 ...
- MathType插件安装
1 安装包下载 版本号:7.4 下载 提取码:fxma 2 安装方法 用安装包内的Key激活即可.软件激活后不能升级. 注意:必须断网或者加入防火墙阻止联网使用! 3 可能遇到的问题 当安装完Math ...
- STL与泛型编程-第一周笔记-Geekband
1, 模板观念与函数模板 简单模板: template< typename T > T Function( T a, T b) {- } 类模板: template struct Obje ...
- Qt源码下载
这是官方下载地址:http://qt.nokia.com/downloads 点击右下角的 ftp.qt.nokia.com - Archive You can find our archive of ...
- 利用animate.css和es6制作文字向上滚动的效果
<!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <link rel= ...
- Django项目:CRM(客户关系管理系统)--81--71PerfectCRM实现CRM项目首页
{#portal.html#} {## ————————46PerfectCRM实现登陆后页面才能访问————————#} {#{% extends 'king_admin/table_index.h ...
- kill 3000
杀3000端口,是作为一个web未开发人员经常遇到的事情 所以我今天就分享一下我的杀3000端口秘诀 lsof -i: 先要找到端口 node zcool 20u IPv6 0xdddbb4f6f12 ...