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

杭州知名网站建设公司众筹网站建设方案模板

杭州知名网站建设公司,众筹网站建设方案模板,云虚拟机搭建wordpress,做柜子比较好看的网站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.yayakq.cn/news/648679/

相关文章:

  • 开发软件的网站WordPress添加内容评论可见
  • 当当网网站建设智慧城市网站建设
  • 比较优秀的国外wordpress网站知乎建站平台
  • vs2010 c 网站开发深圳网站设计技术
  • wordpress网站标签logo网站服务器租用价格怎么算
  • 某物流网站后台源码免费ppt模板公众号
  • 网站推广昔年下拉天水网站制作
  • 深圳网站建设推荐微信公众平台小程序注销
  • 网站备案中兖州住房与城乡建设局网站
  • 那种系统做网站比较好广州最大网站建设
  • dede网站头部不显示调用的名称佛山制作网站公司吗
  • 外包网站开发wordpress字不能
  • 网站页面数怎么做什么是网页和网站
  • 网站需求分析模板托管网站费用
  • 织梦绿色企业网站模板前端需要学什么
  • 旅游网站建设多少钱php论坛源码下载
  • php网站开发遇到的问题整合营销传播策略
  • 移动互联和网站开发一流的菏泽网站建设
  • 潍坊建设网站公司网易邮箱163登录
  • 河源市住房城乡和建设局网站中国平安财产保险公司官网
  • 长沙网站建设大概多少钱wordpress缩略图采集火车头
  • 外贸营销型网站2018甘肃路桥建设集团有限公司网站
  • 医院网站站群建设方案金螳螂装饰公司国内排名
  • 东莞大岭山做网站公司微信公众号 wordpress
  • 沈阳 网站建设建站行业成为买方市场
  • 网站建设维护一年费用有什么网站是可以做动态图的
  • 学院网站建设作用如何制作图片配文字
  • 中企动力网站模板wordpress设置字体
  • 商业网站开发选题的目的红色企业网站
  • 上海做网站设计的公司给网站做cdn