【华为OD机试真题 JS】数组连续和

标题:数组连续和 | 时间限制:1秒 | 内存限制:65536K | 语言限制:不限

给定一个含有N个正整数的数组, 求出有多少个连续区间(包括单个正整数), 它们的和大于等于x。

输入描述:

第一行两个整数N x(0 < N <= 100000, 0 <= x <= 10000000)

第二行有N个正整数(每个正整数小于等于100)。

输出描述:

输出一个整数,表示所求的个数。


示例1

输入

3 7

3 4 7

输出

  • 1
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论
二维数组最大连接面指的是在一个由0和1构成的二维数组中,0与其上下左右相邻的1可以构成一个连通块,而最大连接面就是其中最大的连通块的面积。 解决这个问题可以使用深度优先搜索(DFS)算法。先对数组中的每个点进行搜索,如果该点为1且没有被访问过,则从该点出发对周围的点进行搜索。如果相邻点为1且没有被访问过,则继续从该点出发进行搜索,直到不能继续为止,返回搜索到的面积。搜索过程中需要记录每个点是否被访问过。 具体实现可以使用一个二维数组visited来记录每个点的访问状态,值为true表示已经访问过,false表示未访问。另外还需要维护一个当前连通块的面积和最大面积的变量,初始值都为0。对于每个未访问过的点,从该点出发进行DFS搜索,搜索到的面积加入当前连通块的面积,如果搜索到的面积大于当前最大面积,则更新最大面积。 实现时需要注意边界条件,例如,如果当前搜索到的点在数组边界,则不需要继续搜索该方向。同时可以使用递归或者栈实现DFS算法。 总之,二维数组最大连接面是一个比较典型的图论问题,通过DFS算法可以比较容易地解决。华为OD机试考察该问题,旨在考察应聘者对常用算法的掌握以及对数据结构的应用能力,对于求职者进一步的面试环节会是一项非常有价值的能力测试。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

键盘上Dancer

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值