题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=5247

找连续数

Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)
Total Submission(s): 1207    Accepted Submission(s): 435
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
2015年百度之星程序设计大赛 - 初赛(1)

题目大意:有多少个长度与为k的区间数连续的。

解题思路:依照长度一段一段截取出来,在推断是否连续,这种数据规模超时了==

首先解决是否连续的问题:我採用这个区间的最大值-最小值和长度进行比較。假设相等就是连续的~~可是这样依然超时!

超时的原因是:没询问一次两个for循环。所以要解决问题,相当于打表。

採用一个vis来标记这个数是否出现过,假设出现过就不用再找下去了,出现两个同样数字怎么可能连续下去呢,这里非常easy理解。

再用一个ans的数组来记录长度为1~k的分别有多少个~~这样就能够AC了。

详见代码。

#include <iostream>
#include <cstdio>
#include <algorithm>
#include <cstring>using namespace std;void isSubstr(int st,int len,int c[],int a[])
{int k=1;for (int i=st; i<=st+len-1; i++){c[k++]=a[i];}
}int main()
{int n,m,k;int a[10010],ans[10010];int vis[100010];while (~scanf("%d%d",&n,&m)){for (int i=1; i<=n; i++){scanf("%d",&a[i]);}printf ("Case #1:\n");memset(ans,0,sizeof(ans));for (int i=1; i<=n; i++){memset(vis,0,sizeof(vis));int Max=0,Min=9999999;for (int j=i; j<=n; j++){Max=Max<a[j]?

a[j]:Max; Min=Min>a[j]?a[j]:Min; int l=Max-Min+1; if (!vis[a[j]]) { if (j-i+1==l) ans[l]++; vis[a[j]]=1; } else break; } } while (m--) { scanf("%d",&k); cout<<ans[k]<<endl; } } return 0; }

hdu 5247 找连续数(思维)相关推荐

  1. 2015年百度之星初赛(1) --- B 找连续数

    找连续数 Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others) Total Submi ...

  2. hdu5247找连续数(打表)

    题意(中问题直接粘题意吧)                                 找连续数 Problem Description 小度熊拿到了一个无序的数组,对于这个数组,小度熊想知道是否 ...

  3. hdu5247 找连续数

    Problem Description 小度熊拿到了一个无序的数组,对于这个数组,小度熊想知道是否能找到一个k 的区间,里面的 k 个数字排完序后是连续的. 现在小度熊增加题目难度,他不想知道是否有这 ...

  4. 找连续数(HDU-5247)

    Problem Description 小度熊拿到了一个无序的数组,对于这个数组,小度熊想知道是否能找到一个k 的区间,里面的 k 个数字排完序后是连续的. 现在小度熊增加题目难度,他不想知道是否有这 ...

  5. hdu 7092 仓颉造数 (猜测,手模数据找规律,推公式)

    hdu 7092 仓颉造数 分析: 先考虑一个问题,若平均数能转换成 111 ,那么调和平均数也能转换成 111 ,反之亦然 所以,问题就转换成了,生成平均数,判断平均数是否会出现 111 ,至于能能 ...

  6. 4万次下载,我的这本电子书连续数月蝉联阿里云下载榜冠军!!!

    初学Java的你还在烦恼不知道怎么去学,学习什么内容吗? 那么多的技术书籍是否已经让你无从下手? 别急,这就附上一份完整的Java学习路径.从头开始,给你一个体系化的学习方案. 结合作者(其实就是我) ...

  7. 数组系列—连续数中寻找缺失的数字

    连续数中寻找缺失的数字 通过散列表实现: public static void find(int[] array){Hashtable<Integer,Integer> hasht=new ...

  8. 2019.7.8 校内测试题 连续数和

    题目 连续数和 (num.cpp,1s,128MB) [问题描述]: 一个正整数有可能可以被表示为 n(10^9>=n>=2)个连续正整数之和,如: 15=1+2+3+4+5 15=4+5 ...

  9. 统计数列中是连续数的个数

    数据库环境:SQL SERVER2008R2 今天在群里看到一位网友提的需求,要求统计一组数据中前3位是连续数的个数,具体看贴图. 实现这个需求蛮简单的,说下我的思路: 取前3位,然后减去123,再和 ...

最新文章

  1. 一个使用react native实现的短视频APP
  2. Dubbo自定义日志拦截器
  3. leetcode哈希表(python与c++)
  4. exchange java对象,【原】Java并发程序的一个应用Exchanger的实例
  5. 中国建材50强:利用帆软构建数据管理闭环,数据出错率降低50%
  6. Mac终端神器zsh
  7. CSS浮动为什么不会遮盖同级元素
  8. 共享单车为什么这么重?
  9. ps照片人脸合成教程-----------------------------------
  10. Python的三目表达式and简短语法
  11. 有氧运动和无氧运动 的能量消耗问题
  12. 如何成就一个小而美的存储科技公司?
  13. Android车载蓝牙相关开发1:概述及准备
  14. 用nohup命令让Linux下程序永远在后台执行--zz牧云IT生活
  15. java pdf 套打_itext生成发票套打(操作PDF)
  16. 我的世界java多人不刷溺尸_我的世界:不同版本的三叉戟掉落率不一样?刷了一两百溺尸也没有!...
  17. 洗地机哪个牌子好?口碑最好的洗地机
  18. 万年历单片机C语言报告,51单片机万年历C语言
  19. 2022年下半年软考考科目有这些,快看
  20. 【教程】Western 操作步骤

热门文章

  1. 通过一个函数对比 mgrid以及meshgrid函数
  2. 2021年人工神经网络第一次作业:参考答案-1
  3. 第十六届智能车竞赛广东省线上比赛成绩汇总
  4. RT-Thread智能车培训计划-2021
  5. N-MOS 2N7002晶体管
  6. 今晚有直播 | 全国大学生智能汽车竞赛人工智能创意赛来啦!
  7. AD5933不同频率下的转换结果
  8. dcba oracle,【转】dcba的文章:Oracle的SET UNUSED COLUMN操作到底做了什么?
  9. java优先队列的入队函数,算法与数据结构番外(1):优先队列
  10. anaconda降级python失败_如何降级Python版本安装spyder?