题7-连号区间(暴力不能解决一切)

题目描述

连号区间

代码

最终代码

解题过程

1

刚看完题的时候我没有想太多,直接用递归遍历了所有可能出现的区间,把对应区间的数传给一个新数组,然后排序、遍历数组,如果没有出现不连续的两个数就让计数器加一;提交后发现出现了“java.lang.StackOverflowError”异常,即当前线程的栈满了 ,也就是函数调用层级过多导致。这说明递归层数太多了。
代码如下:
代码上部分
代码下部分
测评结果:
测评结果

2

然后我天真地以为用循环替换掉递归就行了,结果超时了。。
代码如下:
代码上部分
代码下部分
测评结果:
测评结果

3

然后我就开始想别的判断该区间是否为连续区间 办法,奈何天资愚笨,没想出来,于是就去参(zhao)考(chao)了wuli大神@clevercaiquebrightme的代码,如下
wuli大佬
其实很简单,从s到e区间的数如果是连续的,那么该区间的最大数max减去该区间的最小数min的值满足
max-min=e-s
如此就能减少大量计算时间。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值