【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的更多相关文章

  1. 2017 Multi-University Training Contest - Team 3—HDU6058 Kanade's sum

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=6058 题目意思:给你一个排列,求所有区间长度大于等于k的区间第k大的数的和…… 思路:一开始看到区间k ...

  2. 【2017 Multi-University Training Contest - Team 2】TrickGCD

    [Link]:http://acm.hdu.edu.cn/showproblem.php?pid=6053 [Description] 给你一个b数组,让你求一个a数组: 要求,该数组的每一位都小于等 ...

  3. 【2017 Multi-University Training Contest - Team 2】Maximum Sequence

    [Link]:http://acm.hdu.edu.cn/showproblem.php?pid=6047 [Description] 给你一个数列a和一个数列b; 只告诉你a的前n项各是什么; 然后 ...

  4. 【2017 Multi-University Training Contest - Team 2】 Regular polygon

    [Link]: [Description] 给你n个点整数点; 问你这n个点,能够组成多少个正多边形 [Solution] 整点只能构成正四边形. 则先把所有的边预处理出来; 枚举每某两条边为对角线的 ...

  5. 【2017 Multi-University Training Contest - Team 2】 Is Derek lying?

    [Link]: [Description] 两个人都做了完全一样的n道选择题,每道题都只有'A','B','C' 三个选项,,每道题答对的话得1分,答错不得分也不扣分,告诉你两个人全部n道题各自选的是 ...

  6. 【2017 Multi-University Training Contest - Team 5】Rikka with Competition

    [Link]: [Description] [Solution] 把所有人的能力从大到小排; 能力最大的肯定可能拿冠军; 然后一个一个地往后扫描; 一旦出现a[i-1]-a[i]>k; 则说明从 ...

  7. 【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 ...

  8. 【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= ...

  9. 【2017 Multi-University Training Contest - Team 4】Time To Get Up

    [Link]: [Description] [Solution] 把每个数字长什么样存到数组里就好;傻逼题. (直接输入每一行是什么样子更快,不要一个字符一个字符地输入) [NumberOf WA] ...

随机推荐

  1. CSS 预处理语言之 less 篇

    less 前言 Less 是一门 CSS 预处理语言,它扩充了 CSS 语言,增加了诸如变量.混合(mixin).函数等功能,让 CSS 更易维护.方便制作主题.扩充. 安装 客户端使用 // 引入 ...

  2. Winscp远程连接Linux主机,上传和下载文件

    1.安装Winscp.这里不再赘述,网上搜索下载安装就可以 2.点击桌面Winscp快捷键,打开Winscp 3.在打开的页面上填写远程主机的IP,用户名和密码,点击保存,会在页面的左边出现一个站点, ...

  3. python常用函数库收集。

    学习过Python都知道python中有很多库.python本身就是万能胶水,众多强大的库/模块正是它的优势. 收集一些Python常用的函数库,方便大家选择要学习的库,也方便自己学习收集,熟悉运用好 ...

  4. string.split 应用

    采用string.split将字符串依据分隔符,转换成字符串数组,生成的字符串数组中会包含空数组元素,需要通过StringSplitOptions.RemoveEmptyEntries参数选项去除. ...

  5. VC双缓冲画图技术介绍

    双缓冲画图,它是一种主要的图形图像画图技术.首先,它在内存中创建一个与屏幕画图区域一致的对象,然后将图形绘制到内存中的这个对象上,最后把这个对象上的图形数据一次性地拷贝并显示到屏幕上. 这样的技术能够 ...

  6. Mysql基础部分,针对以后python使用

    #redis 非关系型数据库#mysql 关系型数据库 表与表之间有数据关系 Oracle Mysql SqlServer DB2#多张表组合在一起就是数据库#冗余 存储两倍数据 可以使系统速度更快 ...

  7. update-alternatives 命令

    update-alternatives 命令 1.功能作用 update-alternatives是dpkg的实用工具,用来维护系统命令的符号链接,以决定系统默认使用什么命令. 在Debian系统中, ...

  8. jquery中prop()方法和attr()方法

    接着上一篇笔记的疑惑,找了下prop()方法和attr()方法的区别. 原来query1.6中新加了一个方法prop(),一直没用过它,官方解释只有一句话:获取在匹配的元素集中的第一个元素的属性值. ...

  9. 温习 socket http tcp

    Socket是一个接口,可以实现TCP或者UDP的传输HTTP是协议 资料: 1.TCP/IP连接 手机能够使用联网功能是因为手机底层实现了TCP/IP协议,可以使手机终端通过无线网络建立TCP连接. ...

  10. Ace在线编辑器使用requirejs配置

    Ace代码在线编辑器如果需要在requirejs里使用,注意需要使用github上lib/ace目录的文件. 如果使用ajaxorg/ace-builds下面的代码再使用requirejs会报错,不能 ...