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

怎样用php做动态网站今日的重大新闻

怎样用php做动态网站,今日的重大新闻,建wiki网站,seo排名优化软件价格简单翻译一下题目意思: 对于每个 nums[i] 都可以被替换成 [nums[i]-k, nums[i]k] 区间中的任何数,区间左右是闭的。在每个数字可以替换的前提下,返回数组中最多的重复数字的数量。 第一想法是用一个哈希表,Key 是可以被替换的数…

简单翻译一下题目意思:

  • 对于每个 nums[i] 都可以被替换成 [nums[i]-k, nums[i]+k] 区间中的任何数,区间左右是闭的。
  • 在每个数字可以替换的前提下,返回数组中最多的重复数字的数量

第一想法是用一个哈希表,Key 是可以被替换的数,Value 是这个数出现的次数,那最后遍历这个哈希表,找到 Value 最大的就可以。

class Solution {public int maximumBeauty(int[] nums, int k) {int n = nums.length;// 使用哈希表记录每个可能的值出现的次数Map<Integer, Integer> hashMap = new HashMap<>();for (int i = 0; i < n; i++) {// 计算当前元素左右 k 范围内的值int left = nums[i] - k;int right = nums[i] + k;// 在范围内的每个值都增加计数for (int j = left; j <= right; j++) {hashMap.merge(j, 1, Integer::sum);}}int res = 0;// 遍历哈希表,找到出现次数最多的值for (Map.Entry<Integer, Integer> entry : hashMap.entrySet()) {res = Math.max(res, entry.getValue());}return res;}
}

思路是没有问题的,问题是时间复杂度太高,超时。

CleanShot 2024-06-15 at 18.02.56@2x

这时候可以引入扫描线算法,样例 nums = [4,6,1,2], k = 2 对应的替换范围为:

  • [2, 6]
  • [-1, 3]
  • [4, 8]
  • [0, 4]
image-20240615181135890

我们引入一根扫描线,从最小的区间起点开始扫描,计算这根线穿过的最多的区间数量,这个数即我们需要的最多重复数的数量,即「最大美丽值」。

class Solution {public int maximumBeauty(int[] nums, int k) {int n = nums.length;List<List<Integer>> intervals = new ArrayList<>();Arrays.sort(nums);// 为每个数字生成左右区间端点,并存入 intervals 列表for (int i = 0; i < n; i++) {int left = nums[i] - k;int right = nums[i] + k;// 左端点,+1 表示区间开始intervals.add(Arrays.asList(left, 1));  // 右端点,-1 表示区间结束intervals.add(Arrays.asList(right, -1)); }// 排序 intervals,按照左端点升序,左端点相同则按照右端点 +1 在前,-1 在后intervals.sort((a, b) -> {if (a.get(0).equals(b.get(0))) {return b.get(1) - a.get(1);}return a.get(0) - b.get(0);});// 记录最大重叠数int res = 0;// 扫描线变量,记录当前重叠区间数int scan = 0; for (List<Integer> interval : intervals) {// 更新当前重叠区间数scan += interval.get(1); // 更新最大重叠数res = Math.max(res, scan); }// 返回最大重叠数return res; }
}

几个细节:

  • List<Integer> 自定义排序时,记得用 equals 不要用 ==
  • 先按时间排,时间一样再按开始和结束区间排,开始区间在结束区间前处理。
  • 扫描线遇到开始区间,就增加一个重复数,遇到一个结束区间,就减少一个重复数。
http://www.tj-hxxt.cn/news/30749.html

相关文章:

  • 楚风网站建设工作室站内seo优化
  • 西安哪里有做网站的大数据查询官网
  • python不用框架做动态网站手机卡顿优化软件
  • 一个域名权重3如果做网站的话权重会降为0吗百度账户托管
  • 1688网站怎样做推广网络营销是什么
  • 餐饮公司 网站建设怎样去推广自己的网店
  • 网站免费优化营销方案案例
  • 网站建设开发员免费做网页的网站
  • 网站seo优化要懂得做微调百度权重优化软件
  • 郑州400建站网站建设最佳的资源搜索引擎
  • 电子商务网站建设 教案员工培训内容
  • 专业的移动网站建设公河南郑州最新消息
  • 网站怎么做移动适配免费推广平台有哪些
  • 邯郸营销网站建设网络推广的网站有哪些
  • 做免费的网站教程互联网营销软件
  • 桂林市教育局seo图片优化的方法
  • 一起做网店一样的网站平台推广是什么
  • 郑州专业建网站竞猜世界杯
  • 网站该怎么做沈阳专业seo
  • 响应式网站 解决方案营销网站的宣传、推广与运作
  • 政府 网站建设规划2022年今天新闻联播
  • 抚顺网站建设seo关键词排名工具
  • 哪个网站可以免费下载ppt模板推广合作
  • 网站建设在哪块做小红书seo是什么
  • 网站建设 工商注册seo优化sem推广
  • 学生做的网站新网店怎么免费推广
  • 网站建设需不需要编程百度下载官网
  • 做视频播放网站 赚钱查询seo
  • wordpress删除媒体库抖音搜索seo代理
  • 有什么网站是做投资的百度账号