好像没有什么粘文件得分的必要(本来就没多少分了也丢不了多少了)

而且从这次开始小绿框不代表首杀而代表手速了2333

其实我挺菜的,牛一个frepoen送掉100分才跟我并列%%%milkfun mikufun

这一场对于除了他以外的人都是搜索专场。。。

没什么水准但是挺有RP的

话说T1和T3的搜索全写挂我是不是没救了。。。

T1:线性代数

代什么数。。。就是个数字华容道。。。

巨型模拟,因为玩数字华容道的时候并没有总结必胜策略所以考场上什么也不会

乱发现了一些规律,有概率找到解,但是这题子任务评测,所以爆零了。

对的点当然不限于Impossible。如果按测试点评分能有40呢。。。(话说为什么大点找到解的概率反而更大?)

正解就是一种必胜策略。先把(3,3)到(n,n)这个正方形填上,再把(1,3)到(2,n)和(3,1)到(n,2)这两个矩形填上。

填矩形的方法就是对于每个1×2的矩形,(2,n)放到(1,n),(1,n)放到(1,n-1),把0放到(2,n)然后就好了。

具体实现是个大模拟,没时间打了。

T2:装饰

记忆化搜索。

外层全局枚举最终时间,内层记忆化搜索。

根据每一个时刻的决策都可以判断出它到最终时刻为止所产生的影响。

 #include<cstdio>
int TLE,n,f[],E,st[][];
bool sch(int t,int s){//printf("%d %d\n",t,s);
if(s==E)return true;
if(t==TLE)return false;
if(st[t][s]==TLE)return true;
if(st[t][s]==-TLE)return false;
if(sch(t+,s)){st[t][s]=TLE;return true;}
for(int i=;i<=n;++i){
int rs=s;
for(int p=i,T=TLE-t;p&&T;p=f[p],T--)rs^=<<p;
if(sch(t+,rs)){st[t][s]=TLE;return true;}
}
st[t][s]=-TLE;return false;
}
int main(){
freopen("decoration.in","r",stdin);
freopen("decoration.out","w",stdout);
scanf("%d",&n);
for(int i=;i<=n;++i)scanf("%d",&f[i]);
for(int i=,x;i<=n;++i)scanf("%d",&x),E|=x<<i;
for(;TLE<=n;++TLE)if(sch(,))return printf("%d\n",TLE),;
}

T3:午餐

神仙题。%%%mikufun考场切。

首先观察部分分,考虑没有-1的情况。

那每个人都是越早学会越好。

设$f_i$表示第i个人最早在什么时候学会,则有$ f_i=min ( max(f_j,L_{i,j}) ) $

其中$i,j$在一起吃了饭 ,饭的时间的左端点为$L$

这个模型的话可以当作以上式$max$为边权的最短路,这样就可做了。

求出每个人的$f$后判断是否有人应该学会却没学会,枚举每一顿饭根据两个人的$f$来确定饭的时间即可。

考虑有-1的情况。

因为有-1存在,所以有些人就不能太早学会,否则他就会传给-1。

那么处理出每个人在收到-1的限制后,必须在哪一个时刻之后才能学会,设为$h_i$

对于一条边,如果我们想用A更新B。即$h_A$已知而$h_B$未知。

考虑$h_A$与这顿饭时间$L,R$的关系

如果$h_A \geq R$那么$A$必须在这顿饭之后才能学会,所以既然它们吃饭了,那么$B$就不能在$L$之前学会,否则他就会让$A$在$R$之前学会。

只要$B$是在$L$之后学会的,那么把这顿饭的时间定在$[L,h_B)$之间即可。所以就是$h_B$对$L$取$max$。

在不满足$h_A \geq R$ 的情况下,只要你把吃饭的时间定在$R$就一定不会非法,所以这就不会更新$h_B$

所以其实还是一个最短路模型(严格的说,是最长路)。初值是所有-1的点都是$h_i=inf$,多源最长路。

这样求出$h$数组,然后在更新$f$的时候保证$f>h$即可。

无解的条件是$h_1>0$。以及对于任意一个值为1的人不能有$f_i=inf$(未被扩展到)

如果存在解,那么就可以枚举每一顿饭根据两个人的$f$值确定答案。

具体方法是,如果$A,B$两个人其一学会的时间大于这顿饭的$R$,那么定为$L$就行反正没有影响。

否则,这顿饭的时间就是$max(L,f_A,f_B)$,因为这顿饭的时间要将就着后学的人的时间来。

 #include<bits/stdc++.h>
using namespace std;
#define inf 1000000001
priority_queue<pair<int,int> > Q;
priority_queue<pair<int,int>,vector<pair<int,int> >,greater<pair<int,int> > >q;
int n,L[],R[],l[],to[],fir[],cnt,m,s[];
int h[],f[];
void link(int a,int b,int le,int ri){l[++cnt]=fir[a];fir[a]=cnt;to[cnt]=b;L[cnt]=le;R[cnt]=ri;}
int main(){
freopen("lunch.in","r",stdin);
freopen("lunch.out","w",stdout);
scanf("%d%d",&n,&m);
for(int i=,A,B,le,ri;i<=m;++i)
scanf("%d%d%d%d",&A,&B,&le,&ri),link(A,B,le,ri),link(B,A,le,ri);
for(int i=;i<=n;++i)scanf("%d",&s[i]),h[i]=-;
for(int i=;i<=n;++i)if(s[i]==-)Q.push(make_pair(h[i]=inf,i));
while(!Q.empty()){
int p=Q.top().second;Q.pop();
for(int i=fir[p];i;i=l[i])if(R[i]<=h[p]&&h[to[i]]<L[i])
Q.push(make_pair(h[to[i]]=L[i],to[i]));
}
for(int i=;i<=n;++i)f[i]=inf;
q.push(make_pair(,));
while(!q.empty()){
int p=q.top().second;q.pop();
for(int i=fir[p];i;i=l[i]){
int E=max(h[to[i]]+,max(f[p],L[i]));
if(f[to[i]]>E&&E<=R[i])q.push(make_pair(f[to[i]]=E,to[i]));
}
}
if(h[]>)return puts("Impossible"),;
for(int i=;i<=n;++i)if(s[i]==&&f[i]==inf)return puts("Impossible"),;
for(int i=;i<=m;++i){
int a=to[i<<],b=to[(i<<)-],ll=L[i<<],rr=R[i<<];
if(f[a]>rr||f[b]>rr)printf("%d\n",ll);
else printf("%d\n",max(ll,max(f[a],f[b])));
}
}

[考试反思]1102csp-s模拟测试98:苟活的更多相关文章

  1. [考试反思]0718 NOIP模拟测试5

    最后一个是我...rank#11 rank#1和rank#2被外校大佬包揽了. 啊...考的太烂说话底气不足... 我考场上在干些什么啊!!! 20分钟“切”掉T2,又27分钟“切”掉T1 切什么切, ...

  2. csp-s模拟测试98

    csp-s模拟测试98 $T1$??不是我吹我轻松手玩20*20.$T2$装鸭好像挺可做?$T3$性质数据挺多提示很明显? $One$ $Hour$ $Later$ 这$T1$什么傻逼题真$jb$难调 ...

  3. [考试反思]0814NOIP模拟测试21

    前两名是外校的240.220.kx和skyh拿到了190的[暴力打满]的好成绩. 我第5是170分,然而160分就是第19了. 在前一晚上刚刚爆炸完毕后,心态格外平稳. 想想前一天晚上的挣扎: 啊啊啊 ...

  4. [考试反思]1109csp-s模拟测试106:撞词

    (撞哈希了用了模拟测试28的词,所以这次就叫撞词吧) 蓝色的0... 蓝色的0... 都该联赛了还能CE呢... 考试结束前15分钟左右,期望得分300 然后对拍发现T2伪了写了一个能拿90分的垃圾随 ...

  5. [考试反思]0909csp-s模拟测试41:反典

    说在前面:我是反面典型!!!不要学我!!! 说在前面:向rank1某脸学习,不管是什么题都在考试反思后面稍微写一下题解. 这次是真的真的运气好... 这次知识点上还可以,但是答题策略出了问题... 幸 ...

  6. [考试反思]0729NOIP模拟测试10

    安度因:哇哦. 安度因:谢谢你. 第三个rank1不知为什么就来了.迷之二连?也不知道哪里来的rp 连续两次考试数学都占了比较大的比重,所以我非常幸运的得以发挥我的优势(也许是优势吧,反正数学里基本没 ...

  7. [考试反思]0714/0716,NOIP模拟测试3/4

    这几天时间比较紧啊(其实只是我效率有点低我在考虑要不要坐到后面去吹空调) 但是不管怎么说,考试反思还是要写的吧. 第三次考试反思没写总感觉缺了点什么,但是题都刷不完... 一进图论看他们刷题好快啊为什 ...

  8. [考试反思]1003csp-s模拟测试58:沉淀

    稳住阵脚. 还可以. 至少想拿到的分都拿到了,最后一题的确因为不会按秩合并和线段树分治而想不出来. 对拍了,暴力都拍了.挺稳的. 但是其实也有波折,险些被卡内存. 如果内存使用不连续或申请的内存全部使 ...

  9. [考试反思]0816NOIP模拟测试23

    210 210 210 170 还可以.暴力打满就rk4了? 但不管怎么说,总算是在改完题之后理直气壮的写考试反思了. T1是个dp,说水也不太水.(当然某脸只要A掉了一道题就要说那是水题) 我的思路 ...

随机推荐

  1. Spring Security 前后端分离登录,非法请求直接返回 JSON

    hello 各位小伙伴,国庆节终于过完啦,松哥也回来啦,今天开始咱们继续发干货! 关于 Spring Security,松哥之前发过多篇文章和大家聊聊这个安全框架的使用: 手把手带你入门 Spring ...

  2. 利用C++实现模块隐藏(R3层断链)

    一.模块隐藏的实现原理 普通API查找模块实现思路:其通过查询在R3中的PEB(Process Environment Block 进程环境块)与TEB(Thread Environment Bloc ...

  3. 什么是Cookie?——每日一题20190623

    什么是Cookie? Cookie实际上是一小段的文本信息,客户端请求服务器,如果服务器需要记录该用户状态,就使用 response 向客户端浏览器颁发一个Cookie.客户端会把Cookie存起来, ...

  4. Linux内存描述之内存区域zone–Linux内存管理(三)

    服务器体系与共享存储器架构 日期 内核版本 架构 作者 GitHub CSDN 2016-06-14 Linux-4.7 X86 & arm gatieme LinuxDeviceDriver ...

  5. C#中的等值判断1

    目录 简介 值类型和引用类型的相等比较 和相等比较相关的函数 string 和 System.Uri 的等值比较 泛型接口 IEquatable<T> 自定义比较方法 举例 总结 简介 最 ...

  6. e课表项目第二次冲刺周期第六天

    昨天干了什么? 昨天是这次冲刺周期的第五天,我们的冲刺周期已经快过了一半,我们已经实现了对第一层界面的设计,所以我们的进度和我们的时间正好吻合,所以我们有信心完成我们的软件.我在网上搜了一些关于监听的 ...

  7. mac专业视频剪辑软件 Final Cut Pro 10.4.6破解版

    Final Cut Pro简称FCP,它是 Mac平台上最好的视频剪辑软件,可用来视频剪辑.后期特效等.可编辑从标清到4K的各种分辨率视频,ColorSync管理的色彩流水线则可保证全片色彩的一致性. ...

  8. MySQL 数据库的设计规范

    网址 :http://blog.csdn.net/yjjm1990/article/details/7525811 1.文档的建立日期.所属的单位.2.数据库的命名规范.视图.3.命名的规范:1)避免 ...

  9. Centos7安装moloch步骤

      Centos7安装moloch步骤 Moloch 是一个由AOL开源的,能够大规模的捕获IPv4数据包(PCAP).索引和数据库系统,由以下三个部分组成: capture :绑定interface ...

  10. 【Python秘籍】十进制整数与二进制数的转换

    最近在用Python写遗传算法时,发现需要将十进制的整数转换成二进制数,那么怎么来转换呢?当然如果你学过进制转换的有关计算方法,你可以手动编写一些函数来实现,不过总体来说还是比较麻烦的,这里介绍Pyt ...