hdu 5247 找连续数(思维)
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=5247
找连续数
如今小度熊添加题目难度,他不想知道是否有这种 k 的区间,而是想知道有几个这种 k 的区间。
第一行包括两个整数n,m。n代表数组中有多少个数字,m 代表针对于此数组的询问次数,n不会超过10的4次方。m 不会超过1000。第二行包括n个正整数,第 I 个数字代表无序数组的第 I 位上的数字。数字大小不会超过2的31次方。
接下来 m 行,每行一个正整数 k,含义详见题目描写叙述。k 的大小不会超过1000。
(因为仅仅有一组例子,仅仅输出”Case #1:”就可以)
然后对于每一个询问的 k,输出一行包括一个整数。代表数组中满足条件的 k 的大小的区间的数量。
题目大意:有多少个长度与为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 找连续数(思维)相关推荐
- 2015年百度之星初赛(1) --- B 找连续数
找连续数 Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) Total Submi ...
- hdu5247找连续数(打表)
题意(中问题直接粘题意吧) 找连续数 Problem Description 小度熊拿到了一个无序的数组,对于这个数组,小度熊想知道是否 ...
- hdu5247 找连续数
Problem Description 小度熊拿到了一个无序的数组,对于这个数组,小度熊想知道是否能找到一个k 的区间,里面的 k 个数字排完序后是连续的. 现在小度熊增加题目难度,他不想知道是否有这 ...
- 找连续数(HDU-5247)
Problem Description 小度熊拿到了一个无序的数组,对于这个数组,小度熊想知道是否能找到一个k 的区间,里面的 k 个数字排完序后是连续的. 现在小度熊增加题目难度,他不想知道是否有这 ...
- hdu 7092 仓颉造数 (猜测,手模数据找规律,推公式)
hdu 7092 仓颉造数 分析: 先考虑一个问题,若平均数能转换成 111 ,那么调和平均数也能转换成 111 ,反之亦然 所以,问题就转换成了,生成平均数,判断平均数是否会出现 111 ,至于能能 ...
- 4万次下载,我的这本电子书连续数月蝉联阿里云下载榜冠军!!!
初学Java的你还在烦恼不知道怎么去学,学习什么内容吗? 那么多的技术书籍是否已经让你无从下手? 别急,这就附上一份完整的Java学习路径.从头开始,给你一个体系化的学习方案. 结合作者(其实就是我) ...
- 数组系列—连续数中寻找缺失的数字
连续数中寻找缺失的数字 通过散列表实现: public static void find(int[] array){Hashtable<Integer,Integer> hasht=new ...
- 2019.7.8 校内测试题 连续数和
题目 连续数和 (num.cpp,1s,128MB) [问题描述]: 一个正整数有可能可以被表示为 n(10^9>=n>=2)个连续正整数之和,如: 15=1+2+3+4+5 15=4+5 ...
- 统计数列中是连续数的个数
数据库环境:SQL SERVER2008R2 今天在群里看到一位网友提的需求,要求统计一组数据中前3位是连续数的个数,具体看贴图. 实现这个需求蛮简单的,说下我的思路: 取前3位,然后减去123,再和 ...
最新文章
- 一个使用react native实现的短视频APP
- Dubbo自定义日志拦截器
- leetcode哈希表(python与c++)
- exchange java对象,【原】Java并发程序的一个应用Exchanger的实例
- 中国建材50强:利用帆软构建数据管理闭环,数据出错率降低50%
- Mac终端神器zsh
- CSS浮动为什么不会遮盖同级元素
- 共享单车为什么这么重?
- ps照片人脸合成教程-----------------------------------
- Python的三目表达式and简短语法
- 有氧运动和无氧运动 的能量消耗问题
- 如何成就一个小而美的存储科技公司?
- Android车载蓝牙相关开发1:概述及准备
- 用nohup命令让Linux下程序永远在后台执行--zz牧云IT生活
- java pdf 套打_itext生成发票套打(操作PDF)
- 我的世界java多人不刷溺尸_我的世界:不同版本的三叉戟掉落率不一样?刷了一两百溺尸也没有!...
- 洗地机哪个牌子好?口碑最好的洗地机
- 万年历单片机C语言报告,51单片机万年历C语言
- 2022年下半年软考考科目有这些,快看
- 【教程】Western 操作步骤
热门文章
- 通过一个函数对比 mgrid以及meshgrid函数
- 2021年人工神经网络第一次作业:参考答案-1
- 第十六届智能车竞赛广东省线上比赛成绩汇总
- RT-Thread智能车培训计划-2021
- N-MOS 2N7002晶体管
- 今晚有直播 | 全国大学生智能汽车竞赛人工智能创意赛来啦!
- AD5933不同频率下的转换结果
- dcba oracle,【转】dcba的文章:Oracle的SET UNUSED COLUMN操作到底做了什么?
- java优先队列的入队函数,算法与数据结构番外(1):优先队列
- anaconda降级python失败_如何降级Python版本安装spyder?