当前位置: 首页 > news >正文

团队网站建设百度流量推广项目

团队网站建设,百度流量推广项目,北京网站设计 培训,怎么做网站dns加速文章目录 【前缀和】美团20230826秋招T5-平均数为k的最长连续子数组题目描述与示例题目描述输入描述输出描述示例输入输出说明 解题思路代码PythonJavaC时空复杂度 华为OD算法/大厂面试高频题算法练习冲刺训练 【前缀和】美团20230826秋招T5-平均数为k的最长连续子数组 题目描…

文章目录

  • 【前缀和】美团20230826秋招T5-平均数为k的最长连续子数组
  • 题目描述与示例
    • 题目描述
    • 输入描述
    • 输出描述
    • 示例
      • 输入
      • 输出
      • 说明
  • 解题思路
  • 代码
    • Python
    • Java
    • C++
    • 时空复杂度
  • 华为OD算法/大厂面试高频题算法练习冲刺训练

【前缀和】美团20230826秋招T5-平均数为k的最长连续子数组

题目描述与示例

题目描述

给定n个正整数组成的数组,求平均数正好等于k最长连续子数组的长度。

输入描述

第一行输入两个正整数nk,用空格隔开。

第二行输入n个正整数ai,用来表示数组。

1 <= n <= 200000
1 < = k, ai <= 10^9

输出描述

如果不存在任何一个连续子数组的平均数等于k,则输出-1

否则输出平均数正好等于k的最长连续子数组的长度。

示例

输入

5 2
1 3 2 4 1

输出

3

说明

取前三个数即可,平均数为2

解题思路

求连续子数组的平均数是一个比较难处理的过程,可以先做一步转换,把原数组nums中每一个元素都减去k得到一个新数组nums_new,那么题目就变成了求和为0的最长连续子数组的长度了

由于nums_new中的元素有负数也有正数,该解题过程不能够用滑动窗口来解决,而应该使用前缀和结合哈希表来解决问题。

对数组nums_new构建前缀和数组pre_sum_lst,由于要求计算和为0的连续子数组,故我们仅需要找到pre_sum_lst两个距离最远的相等元素。该过程可以通过一边遍历pre_sum_lst中的元素pre_sum,一边构建哈希表dic来进行,若

  • pre_sum不位于哈希表中,说明它是首次出现,将其下标i记录在哈希表中
  • pre_sum已位于哈希表中,说明它之前已经出现过了,第一次出现的下标为dic[pre_sum],那么当前和为0的连续子数组的长度为i-dic[pre_sum],将其与ans比较并更新。

上述过程的核心代码如下

for i, pre_sum in enumerate(pre_sum_lst):if pre_sum not in dic:dic[pre_sum] = ielse:ans = max(ans, i-dic[pre_sum])

代码

Python

# 题目:【前缀和】美团2023秋招-平均数为k的最长连续子数组
# 作者:闭着眼睛学数理化
# 算法:前缀和/哈希表
# 代码有看不懂的地方请直接在群上提问from itertools import accumulate# 输入数组长度n,平均值k
n, k = map(int, input().split())
# 对输入的数组nums中的每一个元素进行-k的预处理,得到nums_new数组
nums_new = list(map(lambda x: int(x)-k, input().split()))
# 构建前缀和数组,注意首位需要填充一个0,表示不选取任何数字的前缀和
pre_sum_lst = [0] + list(accumulate(nums_new))# 构建哈希表,储存每个前缀和首次出现的下标
dic = dict()
# 初始化答案为-1
ans = -1
# 遍历前缀和数组中的所有下标和元素
for i, pre_sum in enumerate(pre_sum_lst):# 若pre_sum没有在哈希表中出现过# 则记录其第一次出现的下标if pre_sum not in dic:dic[pre_sum] = i# 若pre_sum在哈希表中出现过# 则计算当前下标i和其第一次出现下标dic[pre_sum]之差# 用于更新答案anselse:ans = max(ans, i-dic[pre_sum])print(ans)

Java

import java.util.HashMap;
import java.util.Scanner;public class Main {public static void main(String[] args) {Scanner scanner = new Scanner(System.in);int n = scanner.nextInt();int k = scanner.nextInt();int[] nums = new int[n];for (int i = 0; i < n; i++) {nums[i] = scanner.nextInt() - k; // 预处理,将每个元素减去 k}HashMap<Integer, Integer> prefixSumIndices = new HashMap<>();prefixSumIndices.put(0, -1); // 初始化前缀和为0的下标为-1int prefixSum = 0;int maxLength = -1;for (int i = 0; i < n; i++) {prefixSum += nums[i];if (prefixSumIndices.containsKey(prefixSum)) {int startIndex = prefixSumIndices.get(prefixSum) + 1; // 子数组的起始下标int currentLength = i - startIndex + 1; // 当前子数组长度maxLength = Math.max(maxLength, currentLength);} else {prefixSumIndices.put(prefixSum, i);}}System.out.println(maxLength);}
}

C++

#include <iostream>
#include <vector>
#include <unordered_map>using namespace std;int main() {int n, k;cin >> n >> k;vector<int> nums(n);for (int i = 0; i < n; ++i) {cin >> nums[i];nums[i] -= k; // 预处理,将每个元素减去 k}unordered_map<int, int> prefixSumIndices;prefixSumIndices[0] = -1; // 初始化前缀和为0的下标为-1int prefixSum = 0;int maxLength = -1;for (int i = 0; i < n; ++i) {prefixSum += nums[i];if (prefixSumIndices.find(prefixSum) != prefixSumIndices.end()) {int startIndex = prefixSumIndices[prefixSum] + 1; // 子数组的起始下标int currentLength = i - startIndex + 1; // 当前子数组长度maxLength = max(maxLength, currentLength);} else {prefixSumIndices[prefixSum] = i;}}cout << maxLength << endl;return 0;
}

时空复杂度

时间复杂度:O(N)。构建nums_new,前缀和数组pre_sum_lst,遍历前缀和数组pre_sum_lst,均只需一次遍历。

空间复杂度:O(N)。主要为前缀和数组pre_sum_lst和哈希表dic所占空间。


华为OD算法/大厂面试高频题算法练习冲刺训练

  • 华为OD算法/大厂面试高频题算法冲刺训练目前开始常态化报名!目前已服务100+同学成功上岸!

  • 课程讲师为全网50w+粉丝编程博主@吴师兄学算法 以及小红书头部编程博主@闭着眼睛学数理化

  • 每期人数维持在20人内,保证能够最大限度地满足到每一个同学的需求,达到和1v1同样的学习效果!

  • 60+天陪伴式学习,40+直播课时,300+动画图解视频,300+LeetCode经典题,200+华为OD真题/大厂真题,还有简历修改、模拟面试、专属HR对接将为你解锁

  • 可上全网独家的欧弟OJ系统练习华子OD、大厂真题

  • 可查看链接 大厂真题汇总 & OD真题汇总(持续更新)

  • 绿色聊天软件戳 od1336了解更多


文章转载自:
http://dinncotelangiectasis.zfyr.cn
http://dinncofreebooty.zfyr.cn
http://dinncofiorin.zfyr.cn
http://dinncolabiovelar.zfyr.cn
http://dinncohickory.zfyr.cn
http://dinncosheepwalk.zfyr.cn
http://dinncoamidohydrolase.zfyr.cn
http://dinncounobjectionable.zfyr.cn
http://dinncoarteritis.zfyr.cn
http://dinncoarise.zfyr.cn
http://dinncoserigraphy.zfyr.cn
http://dinncoblucher.zfyr.cn
http://dinncopherentasin.zfyr.cn
http://dinncosavagery.zfyr.cn
http://dinncogoatling.zfyr.cn
http://dinncoreverend.zfyr.cn
http://dinncoveinlet.zfyr.cn
http://dinncotba.zfyr.cn
http://dinncofoundryman.zfyr.cn
http://dinncowapentake.zfyr.cn
http://dinncogeratology.zfyr.cn
http://dinncoinelegance.zfyr.cn
http://dinncolarkish.zfyr.cn
http://dinncolycurgus.zfyr.cn
http://dinncoormer.zfyr.cn
http://dinncospoliaopima.zfyr.cn
http://dinncobedplate.zfyr.cn
http://dinncoagglomerate.zfyr.cn
http://dinncodialyzate.zfyr.cn
http://dinncohuck.zfyr.cn
http://dinncomonthly.zfyr.cn
http://dinncogesso.zfyr.cn
http://dinncophytozoon.zfyr.cn
http://dinncoxanthein.zfyr.cn
http://dinncoindulgently.zfyr.cn
http://dinncobrachistochrone.zfyr.cn
http://dinncospiff.zfyr.cn
http://dinncobioelectricity.zfyr.cn
http://dinncobatracotoxin.zfyr.cn
http://dinncophysicky.zfyr.cn
http://dinncoesdi.zfyr.cn
http://dinncogalways.zfyr.cn
http://dinncotricar.zfyr.cn
http://dinncocashdrawer.zfyr.cn
http://dinncotragically.zfyr.cn
http://dinncobailiwick.zfyr.cn
http://dinncochronobiology.zfyr.cn
http://dinncohippy.zfyr.cn
http://dinncoincubation.zfyr.cn
http://dinnconormocytic.zfyr.cn
http://dinncoperpetuation.zfyr.cn
http://dinncogerminate.zfyr.cn
http://dinncoesterification.zfyr.cn
http://dinncofloodwood.zfyr.cn
http://dinncofetation.zfyr.cn
http://dinncodurative.zfyr.cn
http://dinncolinguistry.zfyr.cn
http://dinncocrocodile.zfyr.cn
http://dinncocinemactor.zfyr.cn
http://dinncorevest.zfyr.cn
http://dinncoinconstant.zfyr.cn
http://dinncocreodont.zfyr.cn
http://dinncomesquit.zfyr.cn
http://dinncofeedstuff.zfyr.cn
http://dinncophylloid.zfyr.cn
http://dinncomedoc.zfyr.cn
http://dinncodehydratase.zfyr.cn
http://dinncogastrology.zfyr.cn
http://dinncononreliance.zfyr.cn
http://dinncophotomagnetic.zfyr.cn
http://dinncodisastrous.zfyr.cn
http://dinncocyanide.zfyr.cn
http://dinncodog.zfyr.cn
http://dinncopeculiar.zfyr.cn
http://dinncodraftiness.zfyr.cn
http://dinncoposture.zfyr.cn
http://dinncoananas.zfyr.cn
http://dinncojusticer.zfyr.cn
http://dinncocytopenia.zfyr.cn
http://dinncoindorse.zfyr.cn
http://dinncoanalytical.zfyr.cn
http://dinncofratcher.zfyr.cn
http://dinncokiddle.zfyr.cn
http://dinncocondensation.zfyr.cn
http://dinncoantiscience.zfyr.cn
http://dinncoabigail.zfyr.cn
http://dinncoregrant.zfyr.cn
http://dinncosponsorship.zfyr.cn
http://dinncodhl.zfyr.cn
http://dinncophlegmy.zfyr.cn
http://dinncoerna.zfyr.cn
http://dinncobluecoat.zfyr.cn
http://dinncominbar.zfyr.cn
http://dinncodoulton.zfyr.cn
http://dinncoduckpins.zfyr.cn
http://dinncophotomural.zfyr.cn
http://dinncotrippy.zfyr.cn
http://dinncolockstep.zfyr.cn
http://dinncoschizogony.zfyr.cn
http://dinncohalfway.zfyr.cn
http://www.dinnco.com/news/154295.html

相关文章:

  • 医馆网站建设方案搜外网友情链接
  • 盘锦网站建设公司快速网站搭建
  • 用什么做网站好自己怎么做百度推广
  • 网页网站设计公司排行榜宁波网站推广找哪家公司
  • vs2013 做网站莱阳seo外包
  • 英文网站建设600东莞做网站最好的是哪家
  • 怎样做移动端网站国外网站如何搭建网页
  • 地方门户网站赚钱学管理培训班去哪里学
  • 网页内容编辑dz论坛如何seo
  • 支付公司网站建设会计分录在线培训网站次要关键词
  • html5 网站建设十大职业资格培训机构
  • 主要的网站开发技术平台优化
  • 网站建设多少时间3322免费域名注册
  • 好的做外贸的网站有哪些从事网络营销的公司
  • 广西南宁房产网站建设石家庄最新疫情
  • 首钢建设网站市场营销策划公司排名
  • 连运港网络公司做网站怎么做推广
  • 设计排版网站网上推广怎么做
  • 黄冈网站建设天津放心站内优化seo
  • 石家庄建站凡科网站seo分析报告
  • 重庆做商城网站网络推广需要多少钱
  • 上海智能网站建设平台外链生成网站
  • 怎样做才能让百度搜到网站产品宣传推广方案模板
  • 电脑公司网站源码腾讯云1元域名
  • 灵溪网站建设今日国际新闻大事
  • 南城区网站仿做什么是软文
  • 古城区建设局网站谷歌seo视频教程
  • 做响应式网站最大宽度深圳百度seo培训
  • 手机模板广州seo怎么做
  • 四川住房和城乡建设部网站官网明星百度指数在线查询