[考试反思]1114csp-s模拟测试115:零迟


最后一次了,允许自己混进榜里吧。
没有心态,原题不会做(真的忘了)
T2的搜索没有分。
「 零 · 迟 」:酷刑
只有在最后的时刻才开始意识到,一切的一切都已经晚了。
就在眼前了。没有机会了。
退役,告别OI,粉碎梦想,这,就是最严苛的酷刑。
生存,生存!
HZOI2018!所有人!
一年走来,我们还要继续走下去!
CSP-S,RP++
Hello,HEOI 2020
T1:Tiny Counting
容斥。所有合法四元组-有重复位置的四元组。
#include<cstdio>
#include<algorithm>
using namespace std;
#define S 100005
int n,t[S],a[S],r[S],cnt[S];long long ans,totmn,totmx,lmn[S],rmn[S],lmx[S],rmx[S];
void add(int p){cnt[p]++;for(;p<=n;p+=p&-p)t[p]++;}
int ask(int p,int a=){for(;p;p^=p&-p)a+=t[p];return a;}
int main(){
freopen("a.in","r",stdin);freopen("a.out","w",stdout);
scanf("%d",&n);
for(int i=;i<=n;++i)scanf("%d",&a[i]),r[i]=a[i];
sort(r+,r++n);
for(int i=;i<=n;++i)a[i]=lower_bound(r+,r++n,a[i])-r;
for(int i=;i<=n;++i)lmn[i]=ask(a[i]-),add(a[i]),lmx[i]=i-cnt[a[i]]-lmn[i];
for(int i=;i<=n;++i)t[i]=cnt[i]=;
for(int i=n;i;--i)rmn[i]=ask(a[i]-),add(a[i]),rmx[i]=n-i+-cnt[a[i]]-rmn[i];
for(int i=;i<=n;++i)totmn+=rmn[i],totmx+=rmx[i];
ans=totmn*totmx;
for(int i=;i<=n;++i)ans-=lmn[i]*rmn[i]+lmx[i]*rmx[i]+lmn[i]*lmx[i]+rmn[i]*rmx[i];
printf("%lld\n",ans);
}
T2:Medium Counting
神仙dp。预计改不出来。
空字符是最小的,所以长度不够的串直接往后面塞空字符就行。(其实就是不用动)
dp[i][j][k][l]表示第i~j个串长度为k的后缀已经合法,且第k位都大于等于字符l。
复杂度$O(n^2L \times 26)$
T3:Huge Counting
原题。一部分简化一部分变难。
亏得我还写了那道题的题解。
具体内容差不太多,只不过进制数变为2,而限制的不再是和而是每一个数而已,貌似不是特别难写。
#include<bits/stdc++.h>
using namespace std;
#define mod 990804011
int k;long long dp[][],L[],R[],x[];
long long sch(int al,int st){
if(~dp[al][st])return dp[al][st];
long long ans=;
for(int i=;i<k;++i)if(!(st&<<i)||x[i]&1ll<<al-){
int nst=st;
for(int j=;j<k;++j)if(i!=j&&x[j]&1ll<<al-)nst^=st&<<j;
ans+=sch(al-,nst);
}
int nst=st;
for(int j=;j<k;++j)if(x[j]&1ll<<al-)nst^=st&<<j;
ans+=sch(al-,nst);
return dp[al][st]=ans%mod;
}
long long ask(){
for(int i=;i<k;++i)if(x[i]<)return ;
memset(dp,0xff,sizeof dp);
for(int i=;i<<<k;++i)dp[][i]=;
return sch(,(<<k)-);
}
int main(){
freopen("c.in","r",stdin);freopen("c.out","w",stdout);
int t;long long l,r;scanf("%d",&t);
while(t--){
scanf("%d",&k);
for(int i=;i<=k;++i)scanf("%lld%lld",&L[i],&R[i]);
long long ans=;
for(int i=;i<<<k;++i){
int cnt=;
for(int j=;j<k;++j)if(i&<<j)++cnt,x[j]=L[j+]-;else x[j]=R[j+]-;
ans+=ask()*(cnt&?-:);
}printf("%lld\n",(ans%mod+mod)%mod);
}
}
[考试反思]1114csp-s模拟测试115:零迟的更多相关文章
- [考试反思]0718 NOIP模拟测试5
最后一个是我...rank#11 rank#1和rank#2被外校大佬包揽了. 啊...考的太烂说话底气不足... 我考场上在干些什么啊!!! 20分钟“切”掉T2,又27分钟“切”掉T1 切什么切, ...
- [考试反思]0814NOIP模拟测试21
前两名是外校的240.220.kx和skyh拿到了190的[暴力打满]的好成绩. 我第5是170分,然而160分就是第19了. 在前一晚上刚刚爆炸完毕后,心态格外平稳. 想想前一天晚上的挣扎: 啊啊啊 ...
- [考试反思]0729NOIP模拟测试10
安度因:哇哦. 安度因:谢谢你. 第三个rank1不知为什么就来了.迷之二连?也不知道哪里来的rp 连续两次考试数学都占了比较大的比重,所以我非常幸运的得以发挥我的优势(也许是优势吧,反正数学里基本没 ...
- [考试反思]0714/0716,NOIP模拟测试3/4
这几天时间比较紧啊(其实只是我效率有点低我在考虑要不要坐到后面去吹空调) 但是不管怎么说,考试反思还是要写的吧. 第三次考试反思没写总感觉缺了点什么,但是题都刷不完... 一进图论看他们刷题好快啊为什 ...
- [考试反思]1109csp-s模拟测试106:撞词
(撞哈希了用了模拟测试28的词,所以这次就叫撞词吧) 蓝色的0... 蓝色的0... 都该联赛了还能CE呢... 考试结束前15分钟左右,期望得分300 然后对拍发现T2伪了写了一个能拿90分的垃圾随 ...
- [考试反思]0909csp-s模拟测试41:反典
说在前面:我是反面典型!!!不要学我!!! 说在前面:向rank1某脸学习,不管是什么题都在考试反思后面稍微写一下题解. 这次是真的真的运气好... 这次知识点上还可以,但是答题策略出了问题... 幸 ...
- [考试反思]0801NOIP模拟测试11
8月开门红. 放假回来果然像是神志不清一样. 但还是要接受这个事实. 嗯,说好听点,并列rank#7. 说难听点,垃圾rank#18. 都不用粘人名就知道我是哪一个吧... 因为图片不能太长,所以就不 ...
- [考试反思]1003csp-s模拟测试58:沉淀
稳住阵脚. 还可以. 至少想拿到的分都拿到了,最后一题的确因为不会按秩合并和线段树分治而想不出来. 对拍了,暴力都拍了.挺稳的. 但是其实也有波折,险些被卡内存. 如果内存使用不连续或申请的内存全部使 ...
- [考试反思]0816NOIP模拟测试23
210 210 210 170 还可以.暴力打满就rk4了? 但不管怎么说,总算是在改完题之后理直气壮的写考试反思了. T1是个dp,说水也不太水.(当然某脸只要A掉了一道题就要说那是水题) 我的思路 ...
随机推荐
- 云服务器+域名+hexo 搭建博客
1 阿里云服务器安全组规则中启用80,4000,22端口, 记得出方向也要设置,否则... 2 域名指向服务器ip 3 安装git yum install git 4 安装node.js 下载地址为: ...
- 【JS】395-重温基础:事件
本文是 重温基础 系列文章的第二十篇. 这是第三个基础系列的第一篇,欢迎持续关注呀!重温基础 系列的[初级]和[中级]的文章,已经统一整理到我的[Cute-JavaScript](http://js. ...
- 【算法】331- JS洗牌算法
点击上方"前端自习课"关注,学习起来~ 最近的一个塔罗牌项目中,有一个洗牌的需求,其实也就是随机打乱数组,遂网上搜了下,再此做个整理- 塔罗牌 举例来说,我们有一个如下图所示的数组 ...
- 大数据学习笔记——Hadoop编程实战之Mapreduce
Hadoop编程实战——Mapreduce基本功能实现 此篇博客承接上一篇总结的HDFS编程实战,将会详细地对mapreduce的各种数据分析功能进行一个整理,由于实际工作中并不会过多地涉及原理,因此 ...
- 4个点说清楚Java中synchronized和volatile的区别
作者 : Hollis 回顾一下两个关键字:synchronized和volatile 1.Java语言为了解决并发编程中存在的原子性.可见性和有序性问题,提供了一系列和并发处理相关的关键字,比如sy ...
- 记录我的 python 学习历程-Day07 基础数据类型进阶 / 数据类型之间的转换 / 基础数据类型总结 / 编码的进阶
基础数据类型 str(字符串) str:补充方法练习一遍就行 s.capitalize() 首字母大写,其余变小写 s = 'dyLAn' print(s.capitalize()) # Dylan ...
- 测试开源.net 混淆器ConfuserEx
由于公司业务需要简单的把代码加密混淆,于是了解了一下相关的工具然后打算用ConfuserEx试试. 开源地址:https://github.com/yck1509/ConfuserEx/ 下载地址:h ...
- js方法中参数传过来的值包含括号
前提,传递的id为变量值,比如从后台获取数据循环,在每个循环里调用shenpi()方法,假设传的id包含括号,例如 20190329100833(更正) 这样的数据,那么直接调用会报错,控制台会报错: ...
- NTFS在openwrt下的挂载问题
在openwrt上市可以挂载ntfs分区的,但是如果原来如果搞过win,或者异常关机,那么会遇到以下的错误: root@Openwrt:/etc/config# mount -t ntfs -o rw ...
- CCF-CSP题解 201903-2 二十四点
可枚举. 写栈的主要思想是:一个数栈\(numSta\),一个运算符栈\(opSta\).遇到一个运算符,就把之前优先级\(equal\ or\ greater\ than\)它的运算符处理掉. #i ...