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

如何做摄影网站长沙seo袁飞

如何做摄影网站,长沙seo袁飞,注册域名怎么建设网站,自学网站开发条件LeetCode-347. 前 K 个高频元素【数组 哈希表 分治 桶排序 计数 快速选择 排序 堆(优先队列)】 题目描述:解题思路一:哈希表记录出现次数,然后用最小堆取,因为每次都是弹出最小的,剩下的一定是K…

LeetCode-347. 前 K 个高频元素【数组 哈希表 分治 桶排序 计数 快速选择 排序 堆(优先队列)】

  • 题目描述:
  • 解题思路一:哈希表记录出现次数,然后用最小堆取,因为每次都是弹出最小的,剩下的一定是K个最大的。
  • 解题思路二:直接排序
  • 解题思路三:堆
  • 解题思路三:快速排序

题目描述:

给你一个整数数组 nums 和一个整数 k ,请你返回其中出现频率前 k 高的元素。你可以按 任意顺序 返回答案。

示例 1:

输入: nums = [1,1,1,2,2,3], k = 2
输出: [1,2]
示例 2:

输入: nums = [1], k = 1
输出: [1]

提示:

1 <= nums.length <= 105
k 的取值范围是 [1, 数组中不相同的元素的个数]
题目数据保证答案唯一,换句话说,数组中前 k 个高频元素的集合是唯一的

进阶:你所设计算法的时间复杂度 必须 优于 O(n log n) ,其中 n 是数组大小。

解题思路一:哈希表记录出现次数,然后用最小堆取,因为每次都是弹出最小的,剩下的一定是K个最大的。

import heapq # 默认是最小堆
class Solution:def topKFrequent(self, nums: List[int], k: int) -> List[int]:map_ = {}for i in range(len(nums)):map_[nums[i]] = map_.get(nums[i], 0) + 1pri_que = []for key, freq in map_.items():heapq.heappush(pri_que, (freq, key))if len(pri_que) > k: heapq.heappop(pri_que)result = [0] * kfor i in range(k-1, -1, -1):result[i] = heapq.heappop(pri_que)[1]return result

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

解题思路二:直接排序

class Solution:def topKFrequent(self, nums: List[int], k: int) -> List[int]:count = collections.Counter(nums)return [item[0] for item in count.most_common(k)]

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

解题思路三:堆

class Solution:def topKFrequent(self, nums: List[int], k: int) -> List[int]:count = collections.Counter(nums)heap = [(val, key) for key, val in count.items()]return [item[1] for item in heapq.nlargest(k, heap)]

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

解题思路三:快速排序

在这里插入图片描述

class Solution:def topKFrequent(self, nums: List[int], k: int) -> List[int]:count = collections.Counter(nums)num_cnt = list(count.items())topKs = self.findTopK(num_cnt, k, 0, len(num_cnt) - 1)return [item[0] for item in topKs]def findTopK(self, num_cnt, k, low, high):pivot = random.randint(low, high)num_cnt[low], num_cnt[pivot] = num_cnt[pivot], num_cnt[low]base = num_cnt[low][1]i = lowfor j in range(low + 1, high + 1):if num_cnt[j][1] > base:num_cnt[i + 1], num_cnt[j] = num_cnt[j], num_cnt[i + 1]i += 1num_cnt[low], num_cnt[i] = num_cnt[i], num_cnt[low]if i == k - 1:return num_cnt[:k]elif i > k - 1:return self.findTopK(num_cnt, k, low, i - 1)else:return self.findTopK(num_cnt, k, i + 1, high)

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

http://www.tj-hxxt.cn/news/54665.html

相关文章:

  • 无锡惠山区建设局网站网络营销的特点有
  • 做物流网站的公司seo优化轻松seo优化排名
  • 公司网络宣传方案杭州seo培训
  • 做网站团队的人员安排今日小说排行榜
  • 如何使用电子商务网站短视频培训要多少学费
  • 东圃手机网站制作费用培训机构排名一览表
  • 装饰网站卧室做炕百度2021关键词搜索排行
  • 1688网站一起做网店网站搜什么关键词好
  • 网站需要维护吗2023年新闻摘抄十条
  • 网站建设免费书关键词优化策略有哪些
  • ps怎么做响应式网站布局图广州关键词seo
  • 南阳网站seo公司百度搜索引擎入口登录
  • 在哪家网站做推广好推广软件的渠道有哪些
  • 咪咕动态网站怎么做青岛seo网络优化公司
  • 红酒网站建设广西网络推广公司
  • 南昌大型网站制作辽宁网站seo
  • 网站开发设计工程师工作前景有了域名怎么建网站
  • 天津房屋装修设计公司整站优化系统厂家
  • 网站增加权重网站怎么被收录
  • 网站制作地点怀来网站seo
  • 受欢迎的做网站百度竞价推广方案的制定
  • 网页设计需要学什么k福州网站seo公司
  • 织梦网站模板如何安装今日热点新闻事件摘抄50字
  • 烟台h5网站制作企业网站营销的典型案例
  • 微网站建设网站seo优化步骤
  • 什么是网站的tdk淘大象排名查询
  • 做网站论文研究方法怎么写百度app大全
  • 杭州专业网站岳阳网站设计
  • 延吉 网站建设seo就是搜索引擎广告
  • 百度推广是什么工作游戏优化大师官方下载