【2017 Multi-University Training Contest - Team 3】Kanade's sum
【Link】:http://acm.hdu.edu.cn/showproblem.php?pid=6058
【Description】
给你n个数;
它们是由(1..n)组成的排列;
然后给你一个数字k;
让你求这个序列的所有长度大于等于k的区间的第k大值的和;
【Solution】
数组模拟链表;
我们从小到大枚举数字x,寻找以x为第k大的数字的区间有多少个;
数组中只保留了了大于等于x的数字的信息
(即每次做完数字x为第k大的区间之后,把x删掉);
每次在做x的时候;
在x的左半部分找最近的比它大的k-1个数字,
然后从那第k-1个数字开始,将其位置设置为L,然后初始时刻,右端点位置R设置为x的位置;
因为模拟链表的数组中,存放的都是大于等于x的数字
所以当前的(L..R)这一段的第k大值肯定是数字x的;
(这时设L再往左跳一次会到达tL,R向右跳一次会到达tR);
(则答案加上x*(L-tL)*(tR-R),因为tL+1..L中任意一个数字作为区间左端点,R..rR-1中任意一个数字作为区间右端点,这些区间的k大值都是x)
然后左端点L肯定不能再往左移动了,不然x就不是第k大数了;
于是L往右移动一次;
同时R也跟着往右移动一次
(中间小于x的数字已经在之前的操作中删掉了,可以直接跳到下一个大于等于x的数字)
这样就能保证(L+1,R+1)这段区间也满足x是k大值;
再用上面的增加答案的方法增加答案就好;
直到L变成x为止
可能x左边没有k-1个大于它的数字;
那么就不用找那么多;
然后R提前先往右跳缺少(即却几次才够k-1个数字)次就好;
【NumberOf WA】
1
【Reviw】
利用链表这一工具,快速获取左边和右边最近的若干个大于某个数的位置;
再思考一下如何固定x为第k大值;
再利用乘法原理求出区间个数;
每个区间对答案贡献一样.
从而求出答案;
【Code】
#include <bits/stdc++.h>
using namespace std;
#define LL long long
const int N = 5e5;
int n,T,k,a[N+100],b[N+100][2],pos[N+100];
void del(int x){
int pre = b[x][0],after = b[x][1];
b[pre][1] = after;
b[after][0] = pre;
}
int main(){
scanf("%d",&T);
while (T--){
LL ans = 0;
scanf("%d%d",&n,&k);
for (int i = 1;i <= n;i++){
scanf("%d",&a[i]),b[i][0] = i-1,b[i][1] = i+1;
pos[a[i]] = i;
}
for (int x = 1;x <= n;x++){
int i = pos[x],cntr = 0;
for (int j = 1;j <= k-1;j++){
int ti = b[i][1];
if (ti > n) break;
cntr++;
i = ti;
}
int l = pos[x];
for (int j = 1;j <= (k-1-cntr);j++)
l = b[l][0];
for (int j = i;j >= pos[x] && l;j = b[j][0],l = b[l][0])
ans += 1LL*x*(l-( (b[l][0]) > 0 ? b[l][0]:0))*
( (b[j][1] > n? (n+1):b[j][1]) - j);
del(pos[x]);
}
printf("%lld\n",ans);
}
return 0;
}
【2017 Multi-University Training Contest - Team 3】Kanade's sum的更多相关文章
- 2017 Multi-University Training Contest - Team 3—HDU6058 Kanade's sum
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=6058 题目意思:给你一个排列,求所有区间长度大于等于k的区间第k大的数的和…… 思路:一开始看到区间k ...
- 【2017 Multi-University Training Contest - Team 2】TrickGCD
[Link]:http://acm.hdu.edu.cn/showproblem.php?pid=6053 [Description] 给你一个b数组,让你求一个a数组: 要求,该数组的每一位都小于等 ...
- 【2017 Multi-University Training Contest - Team 2】Maximum Sequence
[Link]:http://acm.hdu.edu.cn/showproblem.php?pid=6047 [Description] 给你一个数列a和一个数列b; 只告诉你a的前n项各是什么; 然后 ...
- 【2017 Multi-University Training Contest - Team 2】 Regular polygon
[Link]: [Description] 给你n个点整数点; 问你这n个点,能够组成多少个正多边形 [Solution] 整点只能构成正四边形. 则先把所有的边预处理出来; 枚举每某两条边为对角线的 ...
- 【2017 Multi-University Training Contest - Team 2】 Is Derek lying?
[Link]: [Description] 两个人都做了完全一样的n道选择题,每道题都只有'A','B','C' 三个选项,,每道题答对的话得1分,答错不得分也不扣分,告诉你两个人全部n道题各自选的是 ...
- 【2017 Multi-University Training Contest - Team 5】Rikka with Competition
[Link]: [Description] [Solution] 把所有人的能力从大到小排; 能力最大的肯定可能拿冠军; 然后一个一个地往后扫描; 一旦出现a[i-1]-a[i]>k; 则说明从 ...
- 【2017 Multi-University Training Contest - Team 5】Rikka with Subset
[Link]: [Description] 给你a数组的n个数的所有2^n个子集的2^n个子集元素的和; 子集元素的和最大为m; 告诉你各个子集元素的和出现的次数; 如 1 2 则0出现1次,1出现1 ...
- 【2017 Multi-University Training Contest - Team 5】Rikka with Graph
[Link]:http://acm.hdu.edu.cn/showproblem.php?pid=6090 [Description] 给你n个点; 让你在这n个点上最多连m条无向边; 使得 ∑ni= ...
- 【2017 Multi-University Training Contest - Team 4】Time To Get Up
[Link]: [Description] [Solution] 把每个数字长什么样存到数组里就好;傻逼题. (直接输入每一行是什么样子更快,不要一个字符一个字符地输入) [NumberOf WA] ...
随机推荐
- PHP安装curl扩展
昨天在写文章的时候,突然出现了一个很顽皮的bug. 一直跳到404页面??? 于是我赶紧打开debug,看看什么情况! 弹出的错误是 :Call to undefined function Home\ ...
- NodeJS学习笔记 (25)逐行读取-readline(ok)
模块概览 readline是个非常实用的模块.如名字所示,主要用来实现逐行读取,比如读取用户输入,或者读取文件内容.常见使用场景有下面几种,本文会逐一举例说明. 文件逐行读取:比如说进行日志分析. 自 ...
- 到2023年将会有超过90%的PC采用SSD硬盘
本文转载自超能网,其他媒体转载需经超能网同意 现在买电脑或者自己装机,还有谁不要SSD硬盘吗?这个问题似乎没什么可说的,SSD硬盘各种好,装机可以说是必选了,但实际上现在的SSD适配率并没有想象中那么 ...
- 说说Kindle那些事
已经不记得是什么时候在哪里听过kindle这玩意的了,反正最开始买kindle还是大四上学期,貌似是2012-9-30,那时候是整个大学最闲的时候,不知道哪天闲的蛋疼一冲动就买了个kindle4黑色款 ...
- python ORM理解、元类
元类 参考链接:https://www.liaoxuefeng.com/wiki/0014316089557264a6b348958f449949df42a6d3a2e542c000/00143191 ...
- 网络芯片应用:GPS公交车行驶记录仪
项目描写叙述 佛罗里达大学学生 Miles Moody 使用WIZnet W5200以太网插板及Arduino Nano剖析了来自一个当地网页服务的HTML代码,并讲述了他每天带着公交车实时GPS坐标 ...
- js插件---图片懒加载echo.js结合 Amaze UI ScrollSpy 使用
js插件---图片懒加载echo.js结合 Amaze UI ScrollSpy 使用 一.总结 一句话总结:图片懒加载echo.js结合 Amaze UI ScrollSpy 使用的效果就是:懒加载 ...
- PL/SQL Developer怎么连接远程数据库
首先打开电脑,到PL/SQL安装的指定目录 [D:\app\DZL\product\10.2.0\dbhome_1\NETWORK\ADMIN]或者[D:\oracle\product\10.2.0\ ...
- 对Jscript操作注册表接口的一点不解
作者:朱金灿 来源:http://blog.csdn.net/clever101 要操作注册表需要通过ActiveX控件调用WScript.shell对象,通过该对象的一些方法来操作.Wshshell ...
- C++的new_handler
这个new_handler其实对应于signal_handler 当operator new申请一个内存失败时,它会进行如下的处理步骤:1.如果存在客户指定的处理函数,则调用处理函数(new_hand ...