自己做出来的第一道倍增(fake)

原题链接

看到题目,贪心水题!不仅思维难度低,代码也好(难)写,三下五除二就写了出来,过了样例。但是一交,只有40pts。一道紫题能让我快速水40pts,良心出题人啊>ω<!

然后我们考虑如何优化这个贪心:

首先我们发现,对于每一个人,在贪心的思路下,他的下一个最优的接替者都是一定的。这表明我们之前\(O(n^2)\)的贪心中,有很多步骤都是不必要的,如果我们能记录一下从某个人开始,经过几轮交替后的接替者是谁就好了。

于是我们令\(f[i][j]\)表示从第\(i\)个人开始,经过\(j\)次交替后的接替者,但很尴尬的是,这样会爆空间,时间复杂度貌似也不好。然后我们想到了倍增:

令\(f[i][j]\)表示从第\(i\)个人开始,经过\(2^j\)次交替后的接替者,\(f[i][j]\)可以从\(f[f[i][j-1]][j-1]\)转移过来,查询的时候我们就像倍增求\(LCA\)一样,从大到小往上跳,直到当前接替者的奔袭区间的右端点距离\(i\)的左端点不小于\(m\)就行了。

还有一个要注意的地方,我们在预处理\(f[i][0]\)时,不能用\(O(n)\)扫一遍。考虑一种极端情况:所有奔袭区间都为定长\(m-1\),且左端点依次相差\(1\),如果我们还扫一遍的话就会被卡回\(O(n^2)\)了。因为奔袭区间没有互相包含,所以左端点不超过当前区间右端点,且离当前区间右端点最近的区间一定是下一个最优选择,我们二分一下左端点就行了。

上代码(倍增题的预处理都巨长,是我写丑了嘛):

#include <cstdio>
#include <algorithm> using namespace std; #define N (int)2e5
#define re register
#define il inline int n, m, l, r, ans[N+5], f[4*N+5][22], power[30]; //注意断环为链 struct Seg {
int id, l, r;
friend bool operator < (const Seg &lhs, const Seg &rhs) {
return lhs.l < rhs.l;
}
}seg[4*N+5]; il int read() {
int s = 0;
char c = getchar();
while(c < '0' || c > '9') c = getchar();
while(c >= '0' && c <= '9') s = s*10+c-'0', c = getchar();
return s;
} il void write(int x) {
if(x > 9) write(x/10);
putchar(x%10+'0');
} il void init() {
n = read(), m = read();
power[0] = 1;
for(re int i = 1; i <= n; ++i) power[i] = (power[i-1]<<1); //预处理2的次幂
for(re int i = 1; i <= n; ++i) {
seg[i].id = seg[i+n].id = i;
seg[i].l = read(), seg[i].r = read();
if(seg[i].l > seg[i].r) seg[i].r += m;
seg[i+n].l = seg[i].l+m, seg[i+n].r = seg[i].r+m;
}
sort(seg+1, seg+2*n+1);
for(re int i = 1, l, r, mid; i <= n; ++i) {
l = i+1, r = 2*n;
while(l != r) { //二分左端点
mid = (l+r)/2;
if(seg[mid].l > seg[i].r) r = mid;
else l = mid+1;
}
f[i][0] = l-1, f[i+n][0] = l-1+n; //初值
}
for(re int j = 1; power[j] <= n; ++j)
for(re int i = 1; i <= n; ++i)
f[i][j] = f[f[i][j-1]][j-1], f[i+n][j] = f[i][j]+n; //递推f数组
} int main() {
init();
for(re int i = 1, cnt, lim, u; i <= n; ++i) {
cnt = 1, lim = seg[i].l+m, u = i;
for(re int j = 20; j >= 0; --j)
if(seg[f[u][j]].id && seg[f[u][j]].r < lim) cnt += power[j], u = f[u][j];
ans[seg[i].id] = cnt+1;
}
for(re int i = 1; i <= n-1; ++i) write(ans[i]), putchar(' ');
write(ans[n]);
return 0;
}

洛谷P4155 BZOJP4444 [SCOI2015]国旗计划的更多相关文章

  1. [luogu] P4155 [SCOI2015]国旗计划(贪心)

    P4155 [SCOI2015]国旗计划 题目描述 A 国正在开展一项伟大的计划 -- 国旗计划.这项计划的内容是边防战士手举国旗环绕边境线奔袭一圈.这项计划需要多名边防战士以接力的形式共同完成,为此 ...

  2. [SCOI2015]国旗计划[Wf2014]Surveillance

    [SCOI2015]国旗计划 A国正在开展一项伟大的计划——国旗计划.这项计划的内容是边防战士手举国旗环绕边境线奔袭一圈.这 项计划需要多名边防战士以接力的形式共同完成,为此,国土安全局已经挑选了N名 ...

  3. 【BZOJ4444】[Scoi2015]国旗计划 双指针+倍增

    [BZOJ4444][Scoi2015]国旗计划 Description A国正在开展一项伟大的计划——国旗计划.这项计划的内容是边防战士手举国旗环绕边境线奔袭一圈.这项计划需要多名边防战士以接力的形 ...

  4. 4444: [Scoi2015]国旗计划

    4444: [Scoi2015]国旗计划 Time Limit: 20 Sec  Memory Limit: 256 MBSubmit: 485  Solved: 232 Description A国 ...

  5. [BZOJ4444] [Luogu 4155] [LOJ 2007] [SCOI2015]国旗计划(倍增)

    [BZOJ4444] [Luogu 4155] [LOJ 2007] [SCOI2015]国旗计划(倍增) 题面 题面较长,略 分析 首先套路的断环为链.对于从l到r的环上区间,若l<=r,我们 ...

  6. 洛谷P4155 [SCOI2015]国旗计划(贪心,树形结构,基数排序)

    洛谷题目传送门 \(O(n)\)算法来啦! 复杂度优化的思路是建立在倍增思路的基础上的,看看楼上几位巨佬的描述吧. 首先数组倍长是一样的.倍增法对于快速找到\(j\)满足\(l_j+m\le r_i\ ...

  7. [bzoj4444] [loj#2007] [洛谷P4155] [Scoi2015] 国旗计划

    Description \(A\) 国正在开展一项伟大的计划--国旗计划.这项计划的内容是边防战士手举国旗环绕边境线奔袭一圈.这项计划需要多名边防战士以接力的形式共同完成,为此,国土安全局已经挑选了 ...

  8. [洛谷OJ] P1114 “非常男女”计划

    洛谷1114 “非常男女”计划 本题地址:http://www.luogu.org/problem/show?pid=1114 题目描述 近来,初一年的XXX小朋友致力于研究班上同学的配对问题(别想太 ...

  9. BZOJ1229 & 洛谷2917:[USACO2008 NOV]toy 玩具 & 洛谷4480:[BJWC2018]餐巾计划问题——题解

    标题很长emmm…… [USACO2008 NOV]toy 玩具 https://www.luogu.org/problemnew/show/P2917 https://www.lydsy.com/J ...

随机推荐

  1. (办公)面试java设计模式

      1.单例模式: 程序开发的时候,有些对象只能有一个.有实例,且只有一个,比如工具类. 修改构造方法为私有的. 饿汉模式: 线程安全 创建一个实例 Private Static 实例; 提供一个静态 ...

  2. ERROR 1071 (42000): Specified key was too long; max key length is 767 bytes

    今天在MySQL 5.6版本的数据库中修改InnoDB表字段长度时遇到了"ERROR 1071 (42000): Specified key was too long; max key le ...

  3. ASP.NET Zero--前期要求

    前期要求 需要以下工具才能使用ASP.NET Zero Core解决方案: Visual Studio 2017 + Visual Studio扩展: Bundler&Minifier Web ...

  4. 关于swagger——WebApi一个controller中出现多个Get是出现错误的处理

    如 /// <summary> /// 测试处理 /// </summary> public class TestController : ApiController { // ...

  5. local_irq_disable和disable_irq的区别

    local_irq_disable: local_irq_disable的功能是屏蔽当前CPU上的所有中断,通过操作arm核心中的寄存器来屏蔽到达CPU上的中断,此时中断控制器中所有送往该CPU上的中 ...

  6. c/c++ 拷贝控制 右值与const引用

    拷贝控制 右值与const引用 背景:当一个函数的返回值是自定义类型时,调用侧用什么类型接收?? 1,如果自定义类型的拷贝构造函数的参数用const修饰了:可以用下面的方式接收. Test t2 = ...

  7. Cs231n课堂内容记录-Lecture 4-Part2 神经网络

    Lecture 7 神经网络二 课程内容记录:https://zhuanlan.zhihu.com/p/21560667?refer=intelligentunit 1.协方差矩阵: 协方差(Cova ...

  8. deepin 15.8桌面系统

    深度桌面环境是深度科技自主开发的美观易用.极简操作的桌面环境,主要由桌面.启动器.任务栏.控制中心.窗口管理器等组成,系统中预装了 WPS Office.搜狗输入法.有道词典.网易云音乐以及深度特色应 ...

  9. IIS出现The specified module could not be found的解决方法

       1.打开IIS 信息服务,在左侧找到自己的计算机,点右键,选择属性,在主属性中选编辑,打开“目录安全性”选项卡,单击“匿名访问和验证控制”里的“编辑”按钮,在弹出的对话框中确保只选中了“匿名访问 ...

  10. 关于Eclipse的版本、分支、衍生版本

    Eclipse 简介: Eclipse的历史: Eclipse的发布版本: Eclipse分支: 关于不同分支版本的区别,点击链接: http://www.eclipse.org/downloads/ ...