hdu 5247(RMQ+枚举)
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=5247
解题思路:这道题要求区间的连续性,可以用RMQ解决。首先可以确定的是如果区间的和必须是满足等差数列的求和,否则不会是连续的数。其次还要判断这个区间内的每一个数往左走遇到第一个与它相等的位置。如果该位置在区间内,说明区间内有重复的数。这里可以用RMQ维护。
#include<iostream>
#include<cstdio>
#include<cstring>
#include<cmath>
#include<map>
using namespace std;const int maxn = 10005;
int n,m,num[maxn],pos[maxn],sum[maxn];
int L[maxn][20],dp[maxn][20];
map<int,int> Map;void init()
{for(int i = 1; i <= n; i++){dp[i][0] = sum[i];L[i][0] = pos[i];}for(int j = 1; (1 << j) <= n; j++)for(int i = 1; i + (1 << j) - 1 <= n; i++){dp[i][j] = min(dp[i][j-1],dp[i+(1<<(j-1))][j-1]);L[i][j] = max(L[i][j-1],L[i+(1<<(j-1))][j-1]);}
}int findMin(int l,int r)
{int k = (int)(log(r - l + 1.0) / log(2.0));return min(dp[l][k],dp[r-(1<<k)+1][k]);
}int findLeft(int l,int r)
{int k = (int)(log(r - l + 1.0) / log(2.0));return max(L[l][k],L[r-(1<<k)+1][k]);
}int main()
{while(scanf("%d%d",&n,&m)!=EOF){Map.clear();for(int i = 1; i <= n; i++){scanf("%d",&sum[i]);pos[i] = Map[sum[i]];Map[sum[i]] = i;}init();for(int i = 1; i <= n; i++)sum[i] += sum[i-1];printf("Case #1:\n");while(m--){int k,ans = 0;scanf("%d",&k);for(int i = 1; i + k -1 <= n; i++){int tmp = findMin(i,i+k-1);if(sum[i+k-1] - sum[i-1] != (tmp + tmp + k - 1) * k / 2) continue;if(findLeft(i,i+k-1) < i) ans++;}printf("%d\n",ans);}}return 0;
}
hdu 5247(RMQ+枚举)相关推荐
- hdu 3486(RMQ+高效枚举)
题意:把n分为 均分为m 段 每段n/m个数字 每段可以选一个最大的数 求这些数相加起来>k的最小的m 解题思路:这道题本来想用二分+rmq的,但discuss里面说二分是错的,所以只能另想别 ...
- hdu 5247 找连续数(思维)
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=5247 找连续数 Time Limit: 2000/1000 MS (Java/Others) M ...
- HDU - 6305 RMQ Similar Sequence(笛卡尔树)
http://acm.hdu.edu.cn/showproblem.php?pid=6305 题目 对于A,B两个序列,任意的l,r,如果RMQ(A,l,r)=RMQ(B,l,r),B序列里的数为[0 ...
- hdu 5340(manacher+枚举)
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=5340 解题思路:首先用manacher处理每个字符,接下来就是要枚举了. 首先是我想到的dp,dp[i ...
- hdu 44313391 Mahjong 枚举,判断
hdu 4431 Mahjong 3391也是差不多的题,但是没有字牌应该简单一点. 我说这个题是一个暴力应该没什么问题,就是判断的时候非常麻烦. 题意 说说打的是日本麻将,不过好像中国的麻将也都是这 ...
- hdu 5265(二分+枚举)
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=5265 解题思路: 首先对每个数进行去模,这样得到的数就会是[0,p-1]的范围,接下来就是如何组合的问 ...
- hdu 5172(RMQ+前缀和)
题意:判断一个区间[l,r]的数是否是1到(r-l+1). 解题思路:首先判断该区间内的和是否是n*(1+n)/2,这里可以用前缀和判断. 接下来是要判断该区间内无重复的数: pos[i]表示第i个数 ...
- HDU 6305 RMQ Similar Sequence(笛卡尔树)
题目链接:RMQ Similar Sequence 题意 首先给定一个长度为 nnn 的整数序列 A={a1,a2,⋯,an}" role="presentation" ...
- [HDU 6305]RMQ Similar Sequence
HDU 6305 题解: 首先B数列一定是一个下标满足二叉搜索树,值满足大根堆的东西. 先考虑B数列满足这个条件的概率. 首先根的元素一定是A数列中最大的(第二关键字是下标最小),考虑B数列中对应的元 ...
最新文章
- 用mpvue实现的微信小程序版cnode社区
- 报名 | 贝叶斯计算方法在生物制药领域的应用(基于SAS)
- 图像旋转的MATLAB和OpenCV源码
- 【Python-ML】SKlearn库特征抽取-LDA
- mysql数据库技术基本操作_MySQL数据库的基础操作
- Failed to execute goal maven-gpg-plugin 1.5 Sign
- 简单易懂的破解脱壳从0开始
- delete请求怎么传参数_postman第2讲-核心功能一:Request(请求)
- headless-virtualbox
- sqlplus中查看sid
- 雨滴win7计算机路径,win7雨滴桌面秀 Raindrop Desktop Show教程_计算机软件和应用程序_IT /计算机_信息...
- VS2019 关闭安全检查
- 中基鸿业工薪家庭理财方法
- SQL实战45.将titles_test表名修改为titles_2017
- 红皮书再总结——实例四
- idea本地项目push到远程仓库报错解决方法
- java交换kv的值_以.kv语言描述OSC
- 那些曾让你哭过的事,总有一天会笑着说出来
- 手机app逆向、渗透测试基础工具介绍
- Flutter syncfusion_flutter_charts 折线图使用心得
热门文章
- 神策用户画像 2 大功能:千人千面,一人千面,一次给你
- leetcode 28. Implement strStr() 实现strStr()
- vue开发黑科技--利用引用类型的值处理复杂数据的编辑
- docker网络之macvlan
- Python3 CookBook | 数字处理
- 修正memcache.php中的错误示例
- php 基础函数写法,字符串,常用函数
- ADO.NET入门教程(一) 初识ADO.NET
- C# 学习笔记1 .NET平台,C#的重要概念
- rejection from Cambridge Machine Learning and Machine Intelligence MPhil