leetcode:6248. 统计中位数为 K 的子数组【问题转化 + 排序二分】
创始人
2024-04-13 20:51:47
0

目录

  • 题目截图
  • 题目分析
  • ac code
  • 总结

题目截图

在这里插入图片描述

题目分析

  • 找到k的位置
  • 然后一步步往左走,一步步往右走
  • 统计左边和右边的比当前k小的和比k大的
  • lst = [[small, big]],分为left和right两部分
  • 可以先一侧的单独看small和big,找到big - small = 0或者1的即可
  • 如果两侧的话,比较麻烦
  • 我们将left和right两侧的再转化成diff = big - small
  • 那么我们需要在左侧找一个diff1和右侧找一个diff2
  • 使得diff1 + diff2 = 0或者1即可
  • 特别地,我们固定diff1,然后可以得到diff2两个可能的值
  • 因此,可以先对diff2排序,再用bisect_left和bisect_right卡住所有可选的值即可

ac code

class Solution:def countSubarrays(self, nums: List[int], k: int) -> int:n = len(nums)k_idx = 0p = [0] * (n + 1)for i, v in enumerate(nums):p[v] = iwhile nums[k_idx] != k:k_idx += 1# s个比k小,s个比k大# s个比k小,s + 1个比k大left, right = k - 1, n - klefts, rights = [], []# 左边的情况small, big = 0, 0for i in range(k_idx - 1, -1, -1):if nums[i] < k:small += 1else:big += 1lefts.append([small, big])# 右边的情况small, big = 0, 0for i in range(k_idx + 1, n):if nums[i] < k:small += 1else:big += 1rights.append([small, big])ans = 1 # 自己# small - big#print(lefts)#print(rights)lefts_diff = []for small, big in lefts:lefts_diff.append(big - small)rights_diff = []for small, big in rights:rights_diff.append(big - small)# print(lefts_diff)# print(rights_diff)# 两个和要等于0或者1ans = 1 # 自己for diff in lefts_diff:if diff == 0 or diff == 1:ans += 1for diff in rights_diff:if diff == 0 or diff == 1:ans += 1rights_diff.sort()for num in lefts_diff:need1 = -numneed2 = 1 - numi = bisect_left(rights_diff, need1)j = bisect_right(rights_diff, need2)ans += j - ireturn ans

总结

  • 一个关键点:比k大的 - 比k小的 = 0或者1
  • 为了研究子数组,我们可以考虑记录左侧连续的和右侧连续的出现的small和big个数
  • 我们需要big1 + big2 - small1 - small2 = 0或者1
  • 直接先变成diff1和diff2使得,diff1 + diff2 = 0或者1
  • 那就好办了
  • 遍历diff1,排序diff2,用二分卡住两边,得到数量即可

相关内容

热门资讯

《山东省医疗纠纷预防和处理办法... 近日,山东省政府网站发布《山东省医疗纠纷预防和处理办法》(以下简称《办法》),依法高效预防和处理医疗...
国常会审议通过《供水条例(草案... 李强主持召开国务院常务会议,审议通过《供水条例(草案)》和《中华人民共和国药品管理法实施条例(修订草...
四川路桥:严格执行国家法律法规... 有投资者在互动平台向四川路桥提问:“请问公司是否针对员工生育或育儿设有相关的福利或激励政策?如有,什...
李强主持召开国务院常务会议,审... 据央视新闻,李强主持召开国务院常务会议,审议通过《供水条例(草案)》和《中华人民共和国药品管理法实施...
《济南市城市更新条例》2026... 大众网记者 刘帅 济南报道 城市更新,是城市高质量发展的“必答题”,更是关乎民生福祉的“民生卷”。 ...
证监会:着力健全REITs信息... 证监会印发《关于推动不动产投资信托基金(REITs)市场高质量发展有关工作的通知》。其中提到,维护市...
追踪报道——“去哪儿网”总部在... 来源:大众日报 在去哪儿网购买的机票却在航司官网查不到,用户向平台注册地北京当地法院起诉却被驳回,按...
思创医惠最新公告:收到杭州市公... 思创医惠(300078.SZ)公告称,公司收到杭州市公安局出具的《移送审查起诉告知书》,公司等涉嫌欺...
2025年A股IPO律师事务所... 文/瑞财经 刘治颖 2025年A股IPO市场收官,全年格局正式落定。 最新数据统计显示,截至12月3...