POI2011 Conspiracy (2-SAT)

Description

  • \(n\leq 5000\)

Solution

  • 发现可拆点然后使用2-SAT做,由于特殊的关系,可以证明每次只能交换两个集合中的一个元素,或者改变一个元素的位置,然后分类讨论即可.
  • 注意特判集合为空的情况.

POI2011 Lollipop (YY)

Description

  • \(n,m\leq 1000000,q\leq 2000000\)

Solution

  • 挖掘题目性质,由于只存在1,2.所以对于一个端点为1的线段,如果它能表示x+1,则一定可以表示出x.
  • 所以预处理从起始点开始的情况,以及从最两边的1开始的情况,就可以解决该问题了.

POI2011 Lightning Conductor

Description

  • \(n\leq 500000,ai\leq 1000000000\)

Solution1

  • 定义
    1. \(dp[i]=Max^{i}_{j=1}(A[j]+\sqrt{i-j})-A[i]\)
    1. \(DP[i]=Max^{n}_{j=i}(A[j]+\sqrt{j-i})-A[i]\)
    1. \(p[i]=Max(dp[i],DP[i])\)
  • 然后根据\(f(x)=\sqrt{x}\)的图像性质可知,\(\sqrt{x}\)为缓增图像.
  • 然后根据该性质可以用类似四边形不等式+分治的方法确定转移区间.
  • 复杂度\(O(nlogn)\)

Solution2

  • 发现可以影响答案的只有\(Mx-\sqrt{n}\)到\(Mx\),同时对于同一数值的点,分散到最两端的才能影响答案.
  • 所以共计最多\(2*\sqrt{n}\)个,然后每个点产生的不同p只有\(sqrt{n}\)个,所以总修改操作只有\(n\)个.
  • 然后使用线段树动态维护区间最大值就好了.
  • 复杂度\(O(nlogn)\)

POI2011 Shift (YY)

Description

  • \(n\leq 2000\)

Solution

  • 由于只关心操作块,所以操作一可以直接抽象成移动一个队头指针,就是把序列头尾相连.
  • 操作二可以看做把某个数在环上向前跳两个.
  • 然后模拟+注意细节即可.

POI2011 Plot (计算几何)

Description

  • \(n\leq 100000\)

Solution

  • 最大值最小->显然需要二分答案,二分最后的半径.
  • 然后就要枚举每个圆心的覆盖的点.
  • 可以贪心地发现:一个圆要尽覆盖尽量多的点.
  • 已知最小覆盖圆算法为O(n)的.
  • 那么直接二分的话复杂度为\(log{n}*n^2log{n}\)
  • 考虑优化,如果让每次二分的量级和最后的答案不会差太大.
  • 那就用类似倍增的方法,每次将枚举的答案区间乘2.
  • 直到不合法时,确定答案在\((2^{k-1},2^{k})\)之内.
  • 然后再倍增一遍.
  • 总复杂度为\(logn * \sum l*logl\)其中\(\sum l =n\) ,所以可以近似为\(nlog^2n\)

POI2011 Strongbox (Math)

Description

  • \(k\leq 250000,n\leq 10^14\)

Solution

  • 对于一个密码a可推广出的密码,可以抽象为\(ax+ny\)在模n意义下的所有非负数解.
  • 裴蜀定理得,这些非负数解一定是gcd(a,n)的倍数.
  • 同时可推广:如果密码集合有两个数互质,那么所有数将会成为答案.
  • 所以总能确定密码集合中所有数是某个数(key)的倍数.
  • 所以确定一个密码a后,key一定是gcd(a,n)的因子.
  • 所以就枚举gcd(a,n)的因子,然后暴力检验是否为之前给的k-1个数与n的gcd的因数(加一点剪枝就过去了)

POI2011 Difference (DP)

Description

  • \(n\leq 1000000\)

Solution

  • 通过枚举出现最少和出现最多的字母,然后跑一遍最大连续和即可.
  • 然后对于某点权值为a,只用更新52种状态.
  • 复杂度\(O(52*n)\).

POI2011 Garbage (Euler Path)

Description

  • \(n\leq 100000,m\leq 1000000\)

Solution

  • 发现对于一个无需改变的边,那么一定会被经过偶数次,那么等于可以把两条简单路径合并成一条.
  • 所以就只关心需要改变的边,跑欧拉回路就可以了.
  • 由于只能跑简单环,所以在dfs下去的时候把x加入栈,然后再遍历到该点的时候弹出.
void Angry_Tiger(int x){
if(vis[x]){
++now;
while(1){
Ans.add(now,Sk[top]);
vis[Sk[top]]=false;
Sz[now]++;
if(Sk[top--]==x)break;
}
}
LFOR(i,x,E){
int y=E[i];
if(mark[i]||mark[i^1])continue;
mark[i]=1;
vis[Sk[++top]=x]=true;
Angry_Tiger(y);
}
}

POI2011 Dynamite(Binary)

Description

  • \(n\leq 300000\)

Solution

  • 首先可以看出答案满足单调性,所以二分答案把题目化作一个判定性问题.
  • 然后要做一个类似于树形dp的东西.
  • 从叶子结点向上转移,当且仅当必须要加点的时候才加点.
  • 要记录两个东西:还未被覆盖且距离自己最远的点(Mx),以及距离自己最近的爆炸点(Mi).
  • 然后若\(Mx+Mi<=mid\),\(Mx=0\)
  • 否则\(Mx==mid\),\(cnt++,Mi=-1,Mx=-1\)

POI2011 Programming Contest(二分图)

Description

  • \(n,m\leq 500,1\leq r,t\leq 10^6\)

Solution

  • 首先有一个结论:集体完成的时间越短越好.
  • 当然这个是在保证做题数不变的情况下.
  • 然后根据这个性质,可以不断推移时间线,然后让每个时间段的做题数尽量多.
  • 这显然是一个二分图匹配,每次匹配的复杂度为\(O(nm)\).
  • 设最后每个人的做题数量为\(A_i\),那么对于一个人,对他做二分图匹配的次数也是\(A_i\)次,已知\(\sum A_i=m\),所以总复杂度为\(O(nm^2)\).

POI2014 Salad Bar(单调栈)

Description

  • \(n\leq 10^6\)

Solution

  • 记p=1,j=-1,Dim \(A_i\)为前缀和.
  • 然后对于一段合法区间[l,r],一定要满足\(A[l]\leq A[x]\leq A[r]\),其中\(x \in [l,r]\) .
  • 那么发现可以使用单调栈维护这个上界和下界.
  • 对于一个二元组\((x,y)\),x表示下界,y表示上界.
  • 那么对于两个二元组a,b 如果\(a.x\leq b.x\)且\(a.y\leq b.y\)那么两者就可以合并成\((a.x,b.y)\).
  • 如果当前\(b.x<a.x\),那应该弹掉栈中的a,因为将没有序列可以和它相接.
  • 然后如果弹完之后栈顶元素a,\(a.y>b.y\),将b加入栈中,不然就执行合并操作.
  • 总复杂度\(O(n)\)
FOR(i,1,c){
now+=abs(B[i]);
if(i==1){
if(B[i]>0){
Sk[++top]=(node){1,now};
ans=max(ans,now);
}
else low=now+1;
}else {
if(B[i]<0){
while(A[Sk[top].a-1]>A[now]&&top)--top;
low=now+1;
}
else{
while(A[Sk[top].b]<=A[now]&&top){
low=Sk[top].a;
--top;
}
Sk[++top]=(node){low,now};
ans=max(ans,now-low+1);
}
}
}

POI2014 Couriers(Segment Tree)

Description

  • \(n,m\leq 5*10^5\)

Solution

  • 这个(r-l+1)/2是一个特别好的性质.
  • 可以先离散权值,然后看左半部分的个数和是否大于sz/2,如果右半部分也不合法,那就无解.
  • 然后这个信息可以用可持久化权值线段树维护.

POI2014 Around the world(尺取)

Description

  • \(n\leq 1000000,s\leq 100\)

Solution

  • 发现这题的复杂度应该为\(O(ns)\).
  • 贪心地考虑,每个点对于当前的x最多能到哪个点.
  • 这个信息可以用单调队列或者尺取解决.
  • 然后利用Dis维护一下深度最后减一下就可以了.
FOR(i,0,n<<1)pre[i]=i;
int l=0,ans=n;
FOR(i,n+1,n<<1){
while(B[i]-B[l]>x)++l;
pre[i]=pre[l];
Dis[i]=Dis[l]+1;
if(i-pre[i]>=n)ans=min(ans,Dis[i]-Dis[pre[i]]);
}

POI做题笔记的更多相关文章

  1. C语言程序设计做题笔记之C语言基础知识(下)

    C 语言是一种功能强大.简洁的计算机语言,通过它可以编写程序,指挥计算机完成指定的任务.我们可以利用C语言创建程序(即一组指令),并让计算机依指令行 事.并且C是相当灵活的,用于执行计算机程序能完成的 ...

  2. C语言程序设计做题笔记之C语言基础知识(上)

    C语言是一种功能强大.简洁的计算机语言,通过它可以编写程序,指挥计算机完成指定的任务.我们可以利用C语言创建程序(即一组指令),并让计算机依指令行事.并且C是相当灵活的,用于执行计算机程序能完成的几乎 ...

  3. SDOI2017 R1做题笔记

    SDOI2017 R1做题笔记 梦想还是要有的,万一哪天就做完了呢? 也就是说现在还没做完. 哈哈哈我竟然做完了-2019.3.29 20:30

  4. SDOI2014 R1做题笔记

    SDOI2014 R1做题笔记 经过很久很久的时间,shzr又做完了SDOI2014一轮的题目. 但是我不想写做题笔记(

  5. SDOI2016 R1做题笔记

    SDOI2016 R1做题笔记 经过很久很久的时间,shzr终于做完了SDOI2016一轮的题目. 其实没想到竟然是2016年的题目先做完,因为14年的六个题很早就做了四个了,但是后两个有点开不动.. ...

  6. LCT做题笔记

    最近几天打算认真复习LCT,毕竟以前只会板子.正好也可以学点新的用法,这里就用来写做题笔记吧.这个分类比较混乱,主要看感觉,不一定对: 维护森林的LCT 就是最普通,最一般那种的LCT啦.这类题目往往 ...

  7. java做题笔记

    java做题笔记 1. 初始化过程是这样的: 1.首先,初始化父类中的静态成员变量和静态代码块,按照在程序中出现的顺序初始化: 2.然后,初始化子类中的静态成员变量和静态代码块,按照在程序中出现的顺序 ...

  8. SAM 做题笔记(各种技巧,持续更新,SA)

    SAM 感性瞎扯. 这里是 SAM 做题笔记. 本来是在一篇随笔里面,然后 Latex 太多加载不过来就分成了两篇. 标 * 的是推荐一做的题目. trick 是我总结的技巧. I. P3804 [模 ...

  9. PKUWC/SC 做题笔记

    去年不知道干了些啥,什么省选/营题都没做. 现在赶应该还来得及(?) 「PKUWC2018」Minimax Done 2019.12.04 9:38:55 线段树合并船新玩法??? \(O(n^2)\ ...

随机推荐

  1. TCP的socket连接

    package newtest; import java.io.BufferedReader; import java.io.IOException; import java.io.InputStre ...

  2. 考研路茫茫——空调教室HDU2242(Tarjan缩点)

    题意:http://acm.hdu.edu.cn/showproblem.php?pid=2242 给你一个图,问你缩完点树上割边的做小绝对值差. 思路: 这题核算起来整整做了我一天(即24个小时)! ...

  3. 学习GTK+ (1) ——编写helloworld

    环境 我使用的是新安装的manjaro 18.1 (kde版),安装新系统后后直接可以开始写代码,不需要安装各种调用的库等. 推荐一个网站,gnome开发者 https://developer.gno ...

  4. 如何理解归一化(Normalization)对于神经网络(深度学习)的帮助?

    如何理解归一化(Normalization)对于神经网络(深度学习)的帮助? 作者:知乎用户链接:https://www.zhihu.com/question/326034346/answer/730 ...

  5. 关于vue项目的文件组织

    最近参与了好几个项目,都是以vue-cli脚手架生成的项目,参与完成之后,有点关于项目文件组织的看法,很想聊聊. 关于目录 由vue-cli脚手架生成的项目,都会生成一个基本的目录格式. 类似于这种, ...

  6. vue中$router 与 $route区别

    vue-router中经常会操作的两个对象\(route和\)router两个. 1.$route对象 $route对象表示当前的路由信息,包含了当前 URL 解析得到的信息.包含当前的路径,参数,q ...

  7. web开发中的Cookie与Session技术

    Cookie Cookie的由来 HTTP协议是无状态的,无状态的意思是每次请求都是独立的,它的执行情况和结果与前面的请求和之后的请求都无直接关系,它不会受前面的请求响应情况直接影响,也不会直接影响后 ...

  8. 手写走通HTTP server 第三版本

    后台 后端 服务端 功能:逻辑处理 算法处理    磁盘交互(数据库   静态文件处理) 要求:健壮性,安全性 并发性能和处理速度 架构合理便于维护扩展 网站后端 httpserver + WebFr ...

  9. 【leetcode】561. Array Partition I

    原题: Given an array of 2n integers, your task is to group these integers into n pairs of integer, say ...

  10. 第四章、前端之BOM和DOM

    目录 第四章.前端之BOM和DOM 一.解释BOM和DOM 二.window对象 三.window子对象 四.弹出框 五.计时相关 六.HTML的DOM树 七.查找元素 八.节点操作 九.JS操作CS ...