找连续数

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 的区间。
 

Input

输入包括一组測试数据。

第一行包括两个整数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 的大小的区间的数量。

 

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]);
}
}
}

最新文章

  1. Day10-线程进程
  2. Eclipse 显示所有文件
  3. spring 后置处理器BeanFactoryPostProcessor和BeanPostProcessor的用法和区别
  4. Atmega8型号细分区别
  5. Linux 2.4.x内核软中断机制
  6. 第五十篇、OC中常用的第三插件
  7. PHP运行出现Notice : Use of undefined constant 的完美解决方案
  8. javaWeb学习总结(8)- JSP中的九个内置对象(4)
  9. 【T-SQL】系列文章全文目录(2017-06-02更新)
  10. iOS多线程开发之NSThread
  11. 重磅推出:AutoProject Studio 自动化项目生成器
  12. gdb调试5--工程项目的断点调试
  13. tomcat服务器安装方法
  14. JMeter使用中遇到的问题:Jmeter Debug - &quot;Unrecognized VM option &#39;+HeapDumpOnOutOfMemoryError&quot;(转载)
  15. 使用WinSCP在Windows和Linux系统之间传输文件
  16. 菜鸟vimer成长记——第2.4章、cmd-line模式
  17. Jqeury ajax 调用C#的后台程序
  18. RAD Studio Demo Code和几个国外FMX网站 good
  19. C/C++心得-面向对象
  20. [转]ASP.NET母版页中对控件ID的处理

热门文章

  1. Python: Write UTF-8 characters to csv file
  2. 创建maven项目是其中的group id和artifact id怎么填写
  3. redis 事件
  4. Android Touch事件传递机制详解 下
  5. linux下crontab使用笔记
  6. AOP技术应用于安全防御与漏洞修复
  7. window脚本命令学习(转)
  8. Windows API 教程(七) hook 钩子监听
  9. Mongodb性能调优
  10. sql server 数据库系统整理——数据表的创建和管理