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

衡水商城网站制作宁德市自然资源局

衡水商城网站制作,宁德市自然资源局,wordpress html cdn,免费建网站视频教程2808. 使循环数组所有元素相等的最少秒数 难度: 中等 题目大意: 给你一个下标从 0 开始长度为 n 的数组 nums 。 每一秒,你可以对数组执行以下操作: 对于范围在 [0, n - 1] 内的每一个下标 i ,将 nums[i] 替换成 nums[i] &…

2808. 使循环数组所有元素相等的最少秒数

难度: 中等

题目大意:

给你一个下标从 0 开始长度为 n 的数组 nums

每一秒,你可以对数组执行以下操作:

  • 对于范围在 [0, n - 1] 内的每一个下标 i ,将 nums[i] 替换成 nums[i]nums[(i - 1 + n) % n] 或者 nums[(i + 1) % n] 三者之一。

注意,所有元素会被同时替换。

请你返回将数组 nums 中所有元素变成相等元素所需要的 最少 秒数。

提示:

  • 1 <= n == nums.length <= 10^5
  • 1 <= nums[i] <= 10^9

示例 1:

输入:nums = [1,2,1,2]
输出:1
解释:我们可以在 1 秒内将数组变成相等元素:
- 第 1 秒,将每个位置的元素分别变为 [nums[3],nums[1],nums[3],nums[3]] 。变化后,nums = [2,2,2,2] 。
1 秒是将数组变成相等元素所需要的最少秒数。

分析

首先我们是不知道最终是会被哪个数给占据的,不一定是数量最多的数字,所以我们要枚举会被哪个数占据,假设是x,那么如果全部被x占据,那么最终需要多少秒能够把全部的数组全部占满呢,思考一下应该是相邻两个x的位置的最大值/2,所以我们只需要存一下每个数字对应的下标就可以了, 注意这个是环形的,所以最左边x的是和最右边的x向对应的

哈希表 + 枚举

class Solution {
public:int minimumSeconds(vector<int>& nums) {int n = nums.size();unordered_map<int, vector<int>> pos;for (int i = 0; i < n; i ++) {int x = nums[i];pos[x].push_back(i);}int res = 1e9;for (auto& [_, p] : pos) {int locmx = p[0] + n - p.back(); // 最左侧和最右侧的数字for (int i = 1; i < p.size(); i ++) {locmx = max(locmx, p[i] - p[i - 1]);}res = min(res, locmx >> 1);}return res;}
};

时间复杂度: O ( n ) O(n) O(n)

结束了

http://www.dinnco.com/news/60640.html

相关文章:

  • 个体户做网站有用吗河北seo公司
  • 天津最好的网站建设成都百度
  • 大收录量的网站怎么做网站关键词优化培训
  • 韩国电商网站百度网盟官网
  • 地区网站建设旅游景区网络营销案例
  • 建设高端网站公司关键词排名优化官网
  • 做文案策划有些网站可看厦门seo代运营
  • 福州专业建站公司深圳网络营销推广招聘网
  • 做网站自己租服务器还是网络公司企业培训权威机构
  • 创建网站有什么用杭州百度seo
  • 云建网站网址西安关键词优化平台
  • 网站后台打打开空白网站收录怎么做
  • 萨wordpressseo域名综合查询
  • 做外贸需要到外汇管理网站百度站长工具排名
  • 免费域名的申请方法海阳seo排名优化培训
  • 网页排版设计软件网站seo哪家公司好
  • 南通做网站优化公司重庆网站建设公司
  • 惠济免费网站建设app开发费用一览表
  • 织梦可以做B2B信息发布网站吗优化电池充电什么意思
  • 天河做网站系统军事网站大全军事网
  • 南通做网站市场监督管理局电话
  • 网站制作软件培训人工在线客服系统
  • 个人在网站怎么做珠海百度推广优化排名
  • 新网站建设运营年计划书网络营销理论基础
  • 哈尔滨龙彩做网站多少钱怎么做百度关键词排名
  • 上传视频网站源码cms网站
  • 北京海淀住建委网站怎样交换友情链接
  • 做交流网站有哪些重庆seo多少钱
  • 哪个网站做外贸好企业邮箱格式
  • 怎么做旅游网站seo网站快速整站优化技术