[考试反思]1004csp-s模拟测试59:惊醒


一句话:我看错考试时间了,我以为11:30结束,T2T3暴力没来得及交。
为什么考试的时间忽然变了啊。。。没转过来
一定要看清考试的起止时间!
虽说T2T3连爆搜都没打,只打特殊性质只有32分。爆搜分还挺高的。
当特殊性质不好扩展时,记得把爆搜打上。
本来是想T1先送上暴力,然后尝试肝T2,然后是T3暴力,有时间再回来优化T1。
但是整场考试时间是崩的,也没回T1。。。然而T2T3
注意分数与时间的权衡。
T1:Reverse
BFS。
二营长打法极其简单。因为是BFS所以一个点不会被多次更新。
那么一次更新了一个区间内的全部奇数或偶数,下次遇到的时候直接跳过就行了。
用链表实现,代码特别特别特别简单。常数也特别小,复杂度O(n),相较于线段树优化建边还少个log。
#include<iostream>
using namespace std;
int dt[],q[],R[],n,m,k,S,x;
int main(){
cin>>n>>k>>m>>S;
for(int i=;i<=n;++i)dt[i]=n+,R[i]=i+;
while(m--)cin>>x,dt[x]=-;
dt[S]=;q[]=S;
for(int h=,t=;h<=t;++h){
int st=max(,q[h]-k+),l=st+st+k--q[h];st=min(n-k+,q[h]);int r=st+st+k--q[h];
for(int i=l;i<=r;i=R[i])if(dt[i]>dt[q[h]]+)dt[i]=dt[q[h]]+,q[++t]=i;
for(int i=l;i<=r;){int rr=R[i];R[i]=max(R[i],r);i=rr;}
}
for(int i=;i<=n;++i)cout<<(dt[i]>n?-:dt[i])<<" ";cout<<endl;
}
T2:Silhouette
神仙数学题,考场上死在容斥上了。
无解的判定就是横纵最大值不同。
不然的话我们把读入序列排序,对答案没有影响。
从大到小扩展,扫每一种权值。
然后这种权值占据的是一个矩形或一个L形,并且要求这个区域内每行每列都恰好出现了这个值。
容斥,f[i]表示一共a行中至少i行不满足条件。
ABab表示的是一个A×B的矩形挖掉一个(A-a)×(B-b)的小矩形之后得到的L形,当前处理的数字是S。
$f[i]=\sum\limits_{i=0}^{a}C_a^i \times (S^i \times ( (S+1)^{A-i} - S^{A-i} ) )^b \times ( S^i \times (S+1)^{a-i} )^{B-b}$
这一类“至少”的容斥也没少做,容斥系数是$(-1)^i$
式子的含义是先选出是哪i行不合条件,$C_a^i$
接下来在A×b的矩阵里选合法的方案,
考虑每一列,其中这不合法的i行不出现数字S,所以是[0,S-1]里面选,$S^i$
然后剩下的行里面需要出现数字S,那就是瞎选的方案减去没出现S的方案,即$( (S+1)^{A-i} - S^{A-i} )$
每一列都是这样,所以要b次方
接下来需要计算那一个a×(B-b)的矩形,被限制不合法的i行还是不能放$S^i$,剩下的随便$(S+1)^{a-i}$
然后每一列都这样,要B-b次方
#include<cstdio>
#include<iostream>
#include<algorithm>
using namespace std;
#define mod 1000000007
#define int long long
int pw(int b,int t,int a=){for(;t;t>>=,b=b*b%mod)if(t&)a=a*b%mod;return a;}
bool com(int a,int b){return a>b;}
int fac[],x[],n,y[],ans=,invv[],inv[];
int C(int b,int t){return fac[b]*inv[t]%mod*inv[b-t]%mod;}
int cal(int A,int B,int a,int b,int s){
int tot=;
for(int i=;i<=a;++i)tot=(tot+pw(mod-,i)*C(a,i)%mod*pw(s,B*i)%mod*pw(pw(s+,A-i)-pw(s,A-i)+mod,b)%mod*pw(pw(s+,a-i),B-b))%mod;
return tot%mod+mod;
}
main(){
fac[]=inv[]=inv[]=fac[]=invv[]=;
for(int i=;i<=;++i)fac[i]=fac[i-]*i%mod,invv[i]=mod-mod/i*invv[mod%i]%mod,inv[i]=inv[i-]*invv[i]%mod;
scanf("%lld",&n);
for(int i=;i<=n;++i)scanf("%lld",&x[i]);
for(int i=;i<=n;++i)scanf("%lld",&y[i]);
sort(x+,x++n,com);sort(y+,y++n,com);
int p1=,p2=;
while(p1<=n||p2<=n){
int num=max(x[p1],y[p2]),cnt1=,cnt2=;
while(p1<=n&&x[p1]==num)p1++,cnt1++;
while(p2<=n&&y[p2]==num)p2++,cnt2++;
ans=ans*cal(p1-,p2-,cnt1,cnt2,num)%mod;
}
printf("%lld\n",ans);
}
Tips:感谢王hecao更正。
T3:Seat
skyh倾情压行注释。
[考试反思]1004csp-s模拟测试59:惊醒的更多相关文章
- [考试反思]0718 NOIP模拟测试5
最后一个是我...rank#11 rank#1和rank#2被外校大佬包揽了. 啊...考的太烂说话底气不足... 我考场上在干些什么啊!!! 20分钟“切”掉T2,又27分钟“切”掉T1 切什么切, ...
- CSPS模拟测试59
这场考得我心态爆炸......... 开场T1只会$n^{2}$,然后发现bfs时每个点只需要被更新一次,其他的更新都是没用的. 也就是说,我们可以只更新还没被更新的点? 于是我先YY了一个链表,发现 ...
- csp-s模拟测试59(10.4)「Reverse」(set)·「Silhouette」(容斥)
A. Reverse 菜鸡wwb又不会了..... 可以线段树优化建边,然而不会所以只能set水了 发现对于k和当前反转点固定的节点x确定奇偶性所到达的节点奇偶性是一定的 那么set维护奇偶点,然后每 ...
- [考试反思]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:沉淀
稳住阵脚. 还可以. 至少想拿到的分都拿到了,最后一题的确因为不会按秩合并和线段树分治而想不出来. 对拍了,暴力都拍了.挺稳的. 但是其实也有波折,险些被卡内存. 如果内存使用不连续或申请的内存全部使 ...
随机推荐
- Java 学习笔记之 Sleep停止线程
Sleep停止线程: 在Sleep状态下被interrupt,interrupted 状态会被擦除,返回false. 线程在Sleep状态下被interrupt: public class Sleep ...
- MySQL-时区导致的时间前后端不一致
背景 今天早上刚上班,就被同事提示,程序的日期处理有问题.数据库里日期为:2019-05-21 11:00:00 而前端显示的日期为:2019-05-21 16:00:00 分析 那肯定是和时区相关了 ...
- 01 python安装与初识
一.简要概述 python学习时设计要大于开发. 二.编程语言 1.分类 编程语言分为高级语言和低级语言.高级语言如python.c#,Java.PHP等,低级语言(基础语言)如C.汇编语言. 2.机 ...
- ELK日志分析系统(4)-elasticsearch数据存储
1. 概述 logstash把格式化的数据发送到elasticsearch以后,elasticsearch负责存储搜索日志数据 elasticsearch的搜索接口还是很强大的,这边不详细展开,因为k ...
- 分享一个移动端rem布局的适配mixin
/*================================================================ 以下为基于ip5 宽度320做的适配,标准html{font-si ...
- Java BIO及实现
发现日常学习过的知识不久就会遗忘,在此只是整理并记录一下学习笔记,做个回忆,并方便以后查阅,若有错误,欢迎指正 网络模型:TCP/IP网络模型是从OSI七层模型中演化来的,osi模型分为物理层,数据链 ...
- 并发新构件之CountDownLatch
CountDownLatch译为倒计时锁存器:JDK描述 :允许一个或多个线程等待直到在其他线程中执行的一组操作完成的同步辅助. A CountDownLatch用给定的计数初始化. awai ...
- Selenium+PhantomJS使用时报错原因
运行下面代码:'''PhantomJS运用''' from selenium import webdriverimport time # 通过keys模拟键盘from selenium.webdriv ...
- 最新2019Pycharm安装破解教程!内附破解码!
本教程仅用作个人学习,请勿用于商业获利,造成后果自负!!! Pycharm安装 在这插一个小话题哈,Pycharm只是一个编译器,并不能代替Python,如果要使用Python,还是需要安装Pytho ...
- R-plotly|交互式甘特图(Gantt chart)-项目管理/学习计划
本文首发于“生信补给站”微信公众号,https://mp.weixin.qq.com/s/CGz51qOjFSJ4Wx_qOMzjiw 更多关于R语言,ggplot2绘图,生信分析的内容,敬请关注小号 ...