HDU 5247 找连续数 (set妙用)
2024-08-31 01:29:18
找连续数
Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)
Total Submission(s): 1008 Accepted Submission(s): 362
Problem Description
小度熊拿到了一个无序的数组,对于这个数组。小度熊想知道能否找到一个k 的区间,里面的 k 个数字排完序后是连续的。
如今小度熊添加题目难度。他不想知道是否有这种 k 的区间。而是想知道有几个这种 k 的区间。
如今小度熊添加题目难度。他不想知道是否有这种 k 的区间。而是想知道有几个这种 k 的区间。
Input
输入包括一组測试数据。
第一行包括两个整数n,m,n代表数组中有多少个数字,m 代表针对于此数组的询问次数,n不会超过10的4次方。m 不会超过1000。
第一行包括两个整数n,m,n代表数组中有多少个数字,m 代表针对于此数组的询问次数,n不会超过10的4次方。m 不会超过1000。
第二行包括n个正整数,第 I 个数字代表无序数组的第 I 位上的数字。数字大小不会超过2的31次方。
接下来 m 行,每行一个正整数 k,含义详见题目描写叙述,k 的大小不会超过1000。
Output
第一行输"Case #i:"。(因为仅仅有一组例子,仅仅输出”Case #1:”就可以)
然后对于每一个询问的 k,输出一行包括一个整数,代表数组中满足条件的 k 的大小的区间的数量。
然后对于每一个询问的 k,输出一行包括一个整数,代表数组中满足条件的 k 的大小的区间的数量。
Sample Input
6 2
3 2 1 4 3 5
3
4
Sample Output
Case #1:
2
2
Source
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=5247
题目分析:用set做。离线预处理满足条件的各长度区间数量,由于set自带排序,因此一旦一个不包括反复数字的连续区间里最大值减去最小值加一等于这个区间长度,那么这个区间就是我们要找的合法区间。记录下来
#include <cstdio>
#include <cstring>
#include <algorithm>
#include <set>
using namespace std;
int const MAX = 1e4 + 5;
int a[MAX], ans[MAX];
set <int> s; int main()
{
int n, m, ca = 1;
while(scanf("%d %d", &n, &m) != EOF)
{
printf("Case #%d:\n", ca ++);
memset(ans, 0, sizeof(ans));
for(int i = 0; i < n; i++)
scanf("%d", &a[i]);
for(int i = 0; i < n; i++)
{
s.clear();
s.insert(a[i]);
ans[1] ++;
for(int j = i + 1; j < n; j++)
{
set <int> :: iterator it;
it = s.find(a[j]);
if(it != s.end())
break;
s.insert(a[j]);
int st = *s.begin();
it --;
int ed = *it;
int sz = s.size();
if(ed - st + 1 == sz)
ans[sz] ++;
}
}
for(int i = 0; i < m; i++)
{
int k;
scanf("%d", &k);
printf("%d\n", ans[k]);
}
}
}
最新文章
- Day10-线程进程
- Eclipse 显示所有文件
- spring 后置处理器BeanFactoryPostProcessor和BeanPostProcessor的用法和区别
- Atmega8型号细分区别
- Linux 2.4.x内核软中断机制
- 第五十篇、OC中常用的第三插件
- PHP运行出现Notice : Use of undefined constant 的完美解决方案
- javaWeb学习总结(8)- JSP中的九个内置对象(4)
- 【T-SQL】系列文章全文目录(2017-06-02更新)
- iOS多线程开发之NSThread
- 重磅推出:AutoProject Studio 自动化项目生成器
- gdb调试5--工程项目的断点调试
- tomcat服务器安装方法
- JMeter使用中遇到的问题:Jmeter Debug - ";Unrecognized VM option &#39;+HeapDumpOnOutOfMemoryError";(转载)
- 使用WinSCP在Windows和Linux系统之间传输文件
- 菜鸟vimer成长记——第2.4章、cmd-line模式
- Jqeury ajax 调用C#的后台程序
- RAD Studio Demo Code和几个国外FMX网站 good
- C/C++心得-面向对象
- [转]ASP.NET母版页中对控件ID的处理