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

visual c 网站开发广州市 网站 建设

visual c 网站开发,广州市 网站 建设,1920网页设计尺寸规范,网站怎么加代码大家好,我是星恒,今天给大家带来的是一道需要感觉规律的题目,只要读懂题目中的规律,就可以做出来了 这道题用到了哈希,还有一个关键点比较类似循环队列 题目:leetcode 2808 给你一个下标从 0 开始长度为 n…

大家好,我是星恒,今天给大家带来的是一道需要感觉规律的题目,只要读懂题目中的规律,就可以做出来了
这道题用到了哈希,还有一个关键点比较类似循环队列

题目:leetcode 2808

给你一个下标从 0 开始长度为 n 的数组 nums 。
每一秒,你可以对数组执行以下操作:

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

注意,所有元素会被同时替换。
请你返回将数组 nums 中所有元素变成相等元素所需要的 最少 秒数。

示例 1:

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

示例 2:

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

示例 3:

输入:nums = [5,5,5,5]
输出:0
解释:不需要执行任何操作,因为一开始数组中的元素已经全部相等。

提示:

  • 1 <= n == nums.length <= 105
  • 1 <= nums[i] <= 109

分析:
阅读题目,大家首先可能对这两个式子有些迷惑:nums[(i - 1 + n) % n] 和 nums[(i + 1) % n]
其实他们就是处理了一下首尾元素:

  • nums[(i - 1 + n) % n]:当元素为首元素时(下标为0),式子变为了nums[n - 1];其他元素相当于nums[i - 1]
  • nums[(i + 1) % n]:当元素为尾元素时(下标为n - 1),式子变为了nums[0];其他元素相当于nums[i + 1]

这样做的目的是可以让首尾相连,感觉首元素和尾元素相邻了

好,知道了这个,我们正式开始分析这道题目:
读题,我们可以知道,一个元素,一次可以将相邻的两个元素下标变为自己的,所以每一秒我们可以影响相邻元素。


结合上面的理论,我们来看这个图

也就是说,变成相等元素所需要的 最少 秒数,就是两个相邻相同元素的 最大 距离 / 2
注意,首尾距离也要计算

至于我们选择哪个作为相同元素更好,我们只要将每一种元素的所需最大秒数求出来比较就可以了

我们来看题解:

题解:

class Solution {public int minimumSeconds(List<Integer> nums) {HashMap<Integer, List<Integer>> mp = new HashMap<>();int n = nums.size(), res = n;for (int i = 0; i < n; ++i) {mp.computeIfAbsent(nums.get(i), k -> new ArrayList<>()).add(i);}for (List<Integer> positions : mp.values()) {int mx = positions.get(0) + n - positions.get(positions.size() - 1);for (int i = 1; i < positions.size(); ++i) {mx = Math.max(mx, positions.get(i) - positions.get(i - 1));}res = Math.min(res, mx / 2);}return res;}
}

注意:
mp.computeIfAbsent(nums.get(i), k -> new ArrayList<>()).add(i);的意思表示key为“i”的键值对是否存在

  • 如果存在则获取i的值,并操作值的list添加数据“i"。
  • 如果不存在,则调用方法,新创建list结构,将"i"添加到list中,再存入到hashMap中。
  • – 这个API适合用于值为集合的

values(): 返回Map集合中所有value组成的以Collection数据类型格式数据。

如果大家有什么思考和问题,可以在评论区讨论,也可以私信我,很乐意为大家效劳。
好啦,今天的每日一题到这里就结束了,如果大家觉得有用,可以可以给我一个小小的赞呢,我们下期再见!

http://www.yayakq.cn/news/626572/

相关文章:

  • 吴江那里有做公司网站的wordpress音乐主题
  • 美丽乡村建设网站赣州推广团队
  • 做网站指导企业宣传网站建设
  • 建立网站实验总结网片点焊机
  • 邢台 网站建设app程序定制开发
  • 保定市城乡建设局官方网站做个网站多少钱 百度能查到的
  • 福州网站开发系列外网域名购买
  • 关于建设企业网站的请示phpcms律师网站源码
  • 企业网站建设最需要的是什么建网站外包公司
  • asp.net 网站设计wordpress小工具功能
  • 福田区住房和建设局官方网站跳转短链接生成
  • 利用对象储存做网站WordPress切换经典编辑器
  • 怎么修改别人做的网站在线html网站开发
  • 一级a做爰片免费网站在线湖北企业商城网站建设
  • 做星座网站山东平台网站建设找哪家
  • 家具品牌网站怎么做wordpress备份至七牛
  • 网站开发团队简介广州网络营销十年乐云seo
  • 网站设计与开发网站策划网站建设使用的什么语言
  • 网站模板怎么用呢外贸营销网站建设
  • 殡仪馆做网站的好处中国交通建设集团有限公司英文名
  • 四川省住房和城乡建设厅官网站网公司部门划分
  • 赣州有做网站推广的公司吗做网站建设费用预算
  • 网站开发需要考什么证升级wordpress无法创建目录
  • 铁岭网站制作做网站linux主机
  • 机关单位网站安全建设邯郸最穷的三个县
  • 海口网站建设维护wordpress wp-postviews
  • html5网站开发实例教程郑州it渠道网
  • 青岛市建设局网站停工连江网站建设
  • 外贸网站开发哪家好.net网站开发步骤
  • 海南智能网站建设报价做碳循环的网站