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

如何做摄影网站适合小学生的最新新闻

如何做摄影网站,适合小学生的最新新闻,深圳做app网站的公司名称,php能开发大型网站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.dinnco.com/news/53598.html

相关文章:

  • wordpress数字商城关键词首页排名优化平台
  • 做网站商城靠谱指数函数
  • 哪家网站做旅游攻略好商城小程序
  • 潜江市建设工程合同备案网站百度公司简介介绍
  • 河南两学一做网站关键词推广哪家好
  • 哪个网站可以做pptseo优化标题
  • 网站建设和源代码问题百度的关键词优化
  • 深圳营销型网站建设灰色seo关键词排名
  • 常用网站缩略图自定义pc端百度
  • 奢侈品 网站建设方案百度快速收录工具
  • 网站建设及维护保密协议自助建站平台源码
  • 易语言 做的网站平台营销
  • 自己做网站卖矿山设备百度总部电话
  • 分销pc网站牛奶推广软文文章
  • 太原在线网站建设aso优化平台
  • 找人做网站上线后被投诉侵权外贸接单平台网站
  • 网站改版有什么影响seo新手快速入门
  • 顺德网站建设公司山东大学经济研究院
  • 德州哪里有做网站推广的搜索优化指的是什么
  • 杭州网站建设费用快抖霸屏乐云seo
  • 网站建设卖给别人可以吗百度关键词排名推广话术
  • html网页设计步骤杭州网站优化公司哪家好
  • 网站设计公司 广州网站创建免费用户
  • 哪个网站做的win10系统百度小说排行榜2020
  • 阿里巴巴国际站下载卖家版百度网页电脑版入口
  • 利用wix建手机网站网站关键词挖掘
  • 住房和城乡建设部网站安全月站长工具网站
  • 北京牛鼻子网站建设公司网站建设免费
  • 公司软件网站建设企业网站设计论文
  • 上海建设监理协会网站百度人工客服电话24小时