Time Limit: 3000MS   Memory Limit: 65536K
Total Submissions: 36   Accepted: 2

Description

有一天,小Q给了小J一些数字,让小J帮忙找到其中最大的数,由于小J是一个程序猿,当然写了一个代码很快的解决了这个问题。这时,邪恶的小Y又出现了,他问小J,假如我只需要知道这些数字中的某个区间的最大值,你还能做嘛?小J经过七七四十九天的思考,终于完美的解决了这道题目,这次,他想也让小Y尝尝苦头,于是他问小Y,我现在想知道存在多少不同的区间的最大值大于等于k,你还能做吗?这次,小Y犯了难,他来请教身为程序猿的你。

Hint:一个区间指alal+1, …, ar,这一段的数且<= r,一个区间的最大值指max{ alal+1,
…, a},两个区间[l1r1]、 [l2r2]不同当且仅当l1不等于l2r1不等于r2

Input

第一行为一个整数T(1<=T<=5),代表样例数。接下来每组样例的第一行读入一个正整数n(1<=n<=100000)。接下来一行读入n个正整数a(1 <= ai <=
100000)。接下来一行一个正整数Q(1<=Q<=100000),表示有Q组询问。接下来Q行,每行一个正整数k(1<= <=100000)。

Output

对于每组样例,先输出“Case #ca:”,ca从1开始。接下来Q行,每行一个正整数,表示存在多少区间大于等于k

Sample Input


1
3
1 2 3
3
1
2
3

Sample Output


Case #1:
6
5

3

这题可以用单调队列做,先处理出以每个数为最大值的区间,然后再把询问都读入,然后按询问的值从大到小排序,然后每次把数字大于等于询问值的区间都加进去,加进去的值为(idx-l[i]+1)*(r[i]-idx+1),注意,如果出现5 4 5的情况,即第一个5和第二个5的边界是相同的,那么就只能加一次。

#include<iostream>
#include<stdio.h>
#include<stdlib.h>
#include<string.h>
#include<math.h>
#include<vector>
#include<map>
#include<set>
#include<queue>
#include<stack>
#include<string>
#include<algorithm>
using namespace std;
typedef long long ll;
#define inf 99999999
#define pi acos(-1.0)
#define maxn 100050
ll a[maxn];
struct node{
int l,r,idx;
}temp;
vector<node>pos[maxn];
vector<node>::iterator it;
int q[1111111][2],l[maxn],r[maxn]; struct node1{
int num,idx;
}question[maxn];
ll ans[maxn]; bool cmp(node1 a,node1 b){
return a.num>b.num;
} int main()
{
int n,m,i,j,T,front,rear,t,cas=0;
scanf("%d",&T);
while(T--)
{
scanf("%d",&n);
for(i=1;i<=n;i++){
scanf("%d",&a[i]);
}
for(i=1;i<=100000;i++)pos[i].clear(); front=1;rear=0;
for(i=1;i<=n;i++){
while(front<=rear && q[rear][0]<=a[i])rear--;
if(front>rear)l[i]=1;
else l[i]=q[rear][1]+1; rear++;
q[rear][0]=a[i];
q[rear][1]=i; } front=1;rear=0;
for(i=n;i>=1;i--){
while(front<=rear && q[rear][0]<=a[i])rear--;
if(front>rear)r[i]=n;
else r[i]=q[rear][1]-1; rear++;
q[rear][0]=a[i];
q[rear][1]=i; } for(i=1;i<=n;i++){
temp.l=l[i];
temp.r=r[i];
temp.idx=i;
pos[a[i] ].push_back(temp);
}
scanf("%d",&t);
for(i=1;i<=t;i++){
scanf("%d",&question[i].num);
question[i].idx=i;
}
sort(question+1,question+1+t,cmp); ll num=100005;
ll sum=0;
for(i=1;i<=t;i++){
while(num>=question[i].num){
ll pre=0,ll,rr;
for(it=pos[num].begin();it!=pos[num].end();it++){
temp=*it;
ll=temp.l;
if(temp.l<=pre){
ll=pre+1;
}
rr=temp.r;
sum+=(temp.idx-ll+1)*(rr-temp.idx+1);
pre=temp.idx;
}
num--;
}
ans[question[i].idx]=sum;
}
cas++;
printf("Case #%d:\n",cas);
for(i=1;i<=t;i++){
printf("%lld\n",ans[i]);
}
}
return 0;
}

1006 How many?的更多相关文章

  1. SCNU 2015ACM新生赛初赛【1006. 3D打印】解题报告

            题目链接详见SCNU 2015新生网络赛 1006. 3D打印 .出题思路来自codevs 3288. 积木大赛,属于模拟题.         首先我们把“选择从第L部分到第R部分”理 ...

  2. PKU 1006

    数学问题吧,有兴趣的可以研究一下“中国剩余定理” // 1006.cpp : 定义控制台应用程序的入口点. // #include "stdafx.h" #include < ...

  3. 【BZOJ】1006: [HNOI2008]神奇的国度

    http://www.lydsy.com/JudgeOnline/problem.php?id=1006 题意:在一个弦图中找最少染色数.(n<=10000, m<=1000000) #i ...

  4. BZOJ 1006 [HNOI2008] 神奇的国度(简单弦图的染色)

    题目大意 K 国是一个热衷三角形的国度,连人的交往也只喜欢三角原则.他们认为三角关系:即 AB 相互认识,BC 相互认识,CA 相互认识,是简洁高效的.为了巩固三角关系,K 国禁止四边关系,五边关系等 ...

  5. POJ 1006 - Biorhythms (中国剩余定理)

    B - Biorhythms Time Limit:1000MS     Memory Limit:10000KB     64bit IO Format:%I64d & %I64u Subm ...

  6. 1006 最长公共子序列Lcs

    1006 最长公共子序列Lcs 基准时间限制:1 秒 空间限制:131072 KB 给出两个字符串A B,求A与B的最长公共子序列(子序列不要求是连续的). 比如两个串为: abcicba abdks ...

  7. PAT乙级 1006. 换个格式输出整数 (15)

    1006. 换个格式输出整数 (15) 时间限制 400 ms 内存限制 65536 kB 代码长度限制 8000 B 判题程序 Standard 作者 CHEN, Yue 让我们用字母B来表示“百” ...

  8. BZOJ 1006 神奇的国度(弦图的染色数)

    题目链接:http://61.187.179.132/JudgeOnline/problem.php?id=1006 题意:给定一个弦图,求最小染色数.就是用最小数目的颜色进行染色使得任意两个相邻的节 ...

  9. 16年大连网络赛 1006 Football Games

    题目链接:http://acm.hdu.edu.cn/contests/contest_showproblem.php?cid=725&pid=1006 Football Games Time ...

  10. BNUOJ 1006 Primary Arithmetic

    Primary Arithmetic 来源:BNUOJ 1006http://www.bnuoj.com/v3/problem_show.php?pid=1006 当你在小学学习算数的时候,老师会教你 ...

随机推荐

  1. 机器学习笔记·adaboost

    一.算法简介 Adaboost算法是一种集成算法,所谓集成算法就是将多个弱的分类器组合在一起变成一个强的分类器.弱分类器通常是指分类效果比随机分类稍微好一点的分类器.就像我们在做一个重要决定的时候,通 ...

  2. python中列表的insert和append的效率对比

    python中insert和append方法都可以向列表中插入数据只不过append默认插入列表的末尾,insert可以指定位置插入元素. 我们来测试一下他俩插入数据的效率: 测试同时对一个列表进行插 ...

  3. .NET Core引入日志(Log4Net篇)

    Demo版本信息如下: VS:2019 框架:.Net Core 3.1 Log4Net:2.0.12 思维导图: [1]添加依赖项 通过nuget添加Log4Net [2]创建公共类 添加公共类Lo ...

  4. 【JS学习】var let const声明变量的异同点

    [JS学习]var let const声明变量的异同点 前言: 本博客系列为学习后盾人js教程过程中的记录与产出,如果对你有帮助,欢迎关注,点赞,分享.不足之处也欢迎指正,作者会积极思考与改正. 总述 ...

  5. python学习笔记 | wordcloud安装指南

    问题: 直接在命令行输入: pip install wordcloud 不出意外,直接报错,显示缺失vc*****.bat,意思是缺失vc版本,这个安装方式基本可以扔掉. 解决: http://t.c ...

  6. explain extended;show warnings

    mysql> explain extended select count(*) from xuehao;+----+-------------+-------+------+---------- ...

  7. kubernets之pod的标签

    一     如何查看pod 的日志 1 通过执行命令查看日志信息 kubectl logs pod_name 二    创建带有标签的pod,一个范例的pod创建yaml文件如下所示 2.1 创建带有 ...

  8. AVA编程中button按钮,actionlistener和mouseClicked区别

    在java的编程中,对于按钮button 有两个事件: 1.actionPerformed 2.mouseClicked 区别: actionPerformed:一般事件,仅侦听鼠标左键的单击事件,右 ...

  9. Springmvc中参数的绑定

    .处理器适配器在执行Handler之前需要把http请求的key/value数据绑定到Handler方法形参数上. 1.默认支持的参数类型: HttpServletRequest,HttpServle ...

  10. 以我的亲身经历,聊聊学python的流程,同时推荐学python的书

    因为干活要用到,所以我大概于19年5月开始学python,大概学了1个月后,我就能干公司的活了,而且这python项目还包含了机器学习等要素,大概3个月后,我还承担了项目里开发机器学习数据分析的任务. ...