Luogu1081 NOIP2012 开车旅行 倍增
为什么NOIP的题目都这么长qwq
话说2012的D1T3和D2T3都是大火题啊qwq
预处理神题
对于这种跳跳跳的题目考虑使用倍增优化枚举。先预处理某个点之后距离最小和次小的城市,然后倍增预处理一大堆东西。设$f_i$表示从$A$开始开$2^i$次车到达的地点,$g_i$表示从$B$开始开$2^i$次车到达的地点,$k_{i,0/1}$表示从$A$开始开$2^i$次车$A$或$B$经过的路程,$l_{i,0/1}$表示从$B$开始开$2^i$次车$A$或$B$经过的路程。注意边界与越界情况的处理。
接下来就可以直接拼凑法跳了,时间复杂度$O((n+q)logn)$
#include<bits/stdc++.h> #define MAXN 100001 using namespace std; inline int read(){ , k = ; char c = getchar(); while(!isdigit(c) && c != '-') c = getchar(); if(c == '-') k = -k , c = getchar(); ) + a + (c ^ ') , c = getchar(); return a * k; } ][] , lb[MAXN][][]; ][] , h[MAXN] , N; set < pair < int , int > > s; inline ? a : -a;} pair < int , int > cul(int ss , int x){ pair < , ); ) ; i >= ; i--) ] && (] + lb[ss][i][] <= x){ t.first += la[ss][i][]; t.second += lb[ss][i][]; ss = f[ss][i][]; } return t; } int main(){ memset(la , , , sizeof(lb)); N = read(); ; i <= N ; i++) h[i] = read(); s.insert(make_pair(h[N] , N)); s.insert(make_pair(h[N - ] , N - )); ) f[N - ][][] = N; ; i ; i--){ set < pair < int , int > > :: iterator t = s.insert(make_pair(h[i] , i)).first; if(t == s.begin()){ f[i][][] = (++s.begin())->second; f[i][][] = (++++s.begin())->second; continue; } set < pair < int , int > > :: iterator t1 = --t , t2 = ++++t; if(t2 == s.end()){ f[i][][] = t1->second; f[i][][] = (--t1)->second; } else{ if(h[i] - t1->first <= t2->first - h[i]){ f[i][][] = t1->second; if(t1 == s.begin()){ f[i][][] = t2->second; continue; } --t1; } else{ f[i][][] = t2->second; if(++t2 == s.end()){ f[i][][] = t1->second; continue; } } ][] = t1->second; ][] = t2->second; } } ; i <= N ; i++){ ][]) la[i][][] = abs(h[i] - h[f[i][][]]); ][]) lb[i][][] = abs(h[i] - h[f[i][][]]); la[i][][] = lb[i][][] = ; } ; i < N ; i++){ f[i][][] = f[f[i][][]][][]; f[i][][] = f[f[i][][]][][]; la[i][][] = la[i][][]; lb[i][][] = lb[f[i][][]][][]; la[i][][] = la[f[i][][]][][]; lb[i][][] = lb[i][][]; } ; << i < N ; i++) ; j <= N - ( << i) ; j++){ f[j][i][] = f[f[j][i - ][]][i - ][]; f[j][i][] = f[f[j][i - ][]][i - ][]; la[j][i][] = la[j][i - ][] + la[f[j][i - ][]][i - ][]; lb[j][i][] = lb[j][i - ][] + lb[f[j][i - ][]][i - ][]; la[j][i][] = la[j][i - ][] + la[f[j][i - ][]][i - ][]; lb[j][i][] = lb[j][i - ][] + lb[f[j][i - ][]][i - ][]; } ; pair < , X0); ; i <= N ; i++){ pair < int , int > t = cul(i , X0); ){ maxN = t; dir = i; } && t.second == && h[dir] < h[i]){ maxN = t; dir = i; } else if(t.second && ((long long)maxN.first * t.second > (long long)maxN.second * t.first || maxN.first * t.second == maxN.second * t.first && h[dir] < h[i])){ maxN = t; dir = i; } } printf("%d\n" , dir); for(X0 = read() ; X0 ; X0--){ int a = read() , b = read(); pair < int , int > t = cul(a , b); printf("%d %d\n" , t.first , t.second); } ; }
Luogu1081 NOIP2012 开车旅行 倍增的更多相关文章
- P1081 [NOIP2012]开车旅行[倍增]
P1081 开车旅行 题面较为啰嗦.大概概括:一个数列,只能从一个点向后走,两种方案:A.走到和自己差的绝对值次小的点B.走到和自己差的绝对值最小点:花费为此差绝对值:若干询问从规定点向后最多花 ...
- luogu1081 [NOIp2012]开车旅行 (STL::multiset+倍增)
先用不管什么方法求出来从每个点出发,A走到哪.B走到哪(我写了一个很沙雕的STL) 然后把每个点拆成两个点,分别表示A从这里出发和B从这里出发,然后连边是要A连到B.B连到A.边长就是这次走的路径长度 ...
- 洛谷1081 (NOIp2012) 开车旅行——倍增预处理
题目:https://www.luogu.org/problemnew/show/P1081 预处理从每个点开始a能走多少.b能走多少.可以像dp一样从后往前推. 但有X的限制.所以该数组可以变成倍增 ...
- Cogs 1264. [NOIP2012] 开车旅行(70分 暴力)
1264. [NOIP2012] 开车旅行 ★★☆ 输入文件:drive.in 输出文件:drive.out 简单对比时间限制:2 s 内存限制:128 MB [题目描述] 小A 和小 ...
- $Noip2012\ Luogu1081$ 开车旅行 倍增优化$ DP$
Luogu Description Sol 1.发现对于每个城市,小A和小B的选择是固定的,可以预处理出来,分别记为ga[],gb[] 2.并且,只要知道了出发城市和出发天数,那么当前城市和小A,小B ...
- 【vijos1780】【NOIP2012】开车旅行 倍增
题目描述 有\(n\)个城市,第\(i\)个城市的海拔为\(h_i\)且这\(n\)个城市的海拔互不相同.编号比较大的城市在东边.两个城市\(i,j\)之间的距离为\(|h_i-h_j|\) 小A和小 ...
- NOIP2012开车旅行 【倍增】
题目 小 A 和小 B 决定利用假期外出旅行,他们将想去的城市从 1 到 N 编号,且编号较小的城市在编号较大的城市的西边,已知各个城市的海拔高度互不相同,记城市 i 的海拔高度为Hi,城市 i 和城 ...
- 【NOIP2012提高组】开车旅行 倍增
题目分析 朴素的做法就是预处理下一个目的地,然后跑模拟,超时. 本题最重要的考点是倍增优化.设$fa[i][j]$表示a从i出发行驶$2^j$“次”后行驶的路程,$fb[i][j]$表示从i出发行驶$ ...
- noip2012开车旅行 题解
题目大意: 给出n个排成一行的城市,每个城市有一个不同的海拔.定义两个城市间的距离等于他们的高度差的绝对值,且绝对值相等的时候海拔低的距离近.有两个人轮流开车,从左往右走.A每次都选最近的,B每次都选 ...
随机推荐
- vue-cli脚手架之webpack.test.conf.js
webpack单元测试配置: // This is the webpack config used for unit tests. var utils = require('./utils')//ut ...
- LearnX控件漏洞挖掘与利用
前言 大学英语会用到一个 ActiveX 插件 LearnX ,最近从网上下了一个下来分析了一下,找到了一些漏洞并完成了 exploit . 虽然涉及的知识比较老旧,不过还是挺有意思的.这里分享一下整 ...
- recovery 差分升级包制作超时
我们在对android系统升级的时候,可以减少升级包的大小,只升级差异部分,也就是差分包升级,相关的描述可以参考:http://blog.csdn.net/csdn66_2016/article/de ...
- python第五十二天---第九周作业 类 Fabric 主机管理程序
类 Fabric 主机管理程序开发:1. 运行程序列出主机组或者主机列表2. 选择指定主机或主机组3. 选择让主机或者主机组执行命令或者向其传输文件(上传/下载)4. 充分使用多线程或多进程5. 不同 ...
- log4net写入日志到sqlserver数据库
1.添加log4Net配置文件log4net.config 配置文件属性设置为: 配置如下: <?xml version="1.0" encoding="utf-8 ...
- Alpha冲刺! Day5 - 砍柴
Alpha冲刺! Day5 - 砍柴 今日已完成 晨瑶:review了业务逻辑表格,确定了工具类具体函数有哪些:讨论确定了记录的存储方式为HTML. 昭锡:继续学习Gson,并写出json基本操作的D ...
- Python 使用 xlwings 往 excel中写入一列数据的两种方法
1.准备一个二维列表,然后再range后面不指定任何选项,可以输出该二维列表中数据在一列中显示,如下代码: # -*- coding:utf-8 -*- import xlwings as xw li ...
- 微软公布针对最新IE漏洞的安全通报2963983
版权声明:本文为博主原创文章,未经博主同意不得转载. https://blog.csdn.net/MSSecurity/article/details/24637607 微软于昨天公布了一篇最新 ...
- c++ 常成员函数 和 常对象
版权声明:本文为博主原创文章.未经博主同意不得转载. https://blog.csdn.net/zhuyingqingfen/article/details/31751111 先明白几个概念: 1. ...
- java通过传入的日期,获取所在周的周一至周日
public static void main(String[] args) { try { SimpleDateFormat sdf=new SimpleDateFormat("yyyy- ...