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

如何做摄影网站云南优化公司

如何做摄影网站,云南优化公司,境外域名注册,做网站如何在百度快照上排名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.hengruixuexiao.com/news/31185.html

相关文章:

  • 网络平台搭建班级优化大师怎么下载
  • html怎么添加图片为背景优化课程设置
  • 西安网站建设中企建站百度seo关键词排名优化工具
  • 兰州网站优化服务广州关键词排名推广
  • 做二手车那个网站会员性价比高百度关键词推广公司
  • 郑州网站建设公司哪家好网络营销电子版教材
  • 网站建设客户来源怎么在百度发帖
  • 南昌企业制作网站农村电商平台
  • 手机网站的作用域名访问网站
  • h5制作软件 知乎百度起诉seo公司
  • 汽车门户网站有哪些网络推广服务费
  • 福州外网站建设网站怎么优化到首页
  • 18款禁用黄在线观看免费网站seo快速排名优化的软件
  • 外贸专业网站的公司代发关键词包收录
  • 网站建设销售话术流量推广平台
  • 用电脑做兼职的网站比较好网络营销的现状
  • 网站建设内部流程图百度关键词seo
  • 什么网站可以做海报平台推广是什么工作
  • 苏州做网站公司电话长沙疫情最新情况
  • 手机域名做网站中国谁第一家自己如何做网站
  • 天元建设集团有限公司鹿腾衡阳seo排名
  • 做动画 的 网站有哪些软件seo实战密码电子版
  • 淄博做网站建设的公司唐山seo排名外包
  • 南宁两学一做党课网站百度建站官网
  • 网站群建设系统武汉做seo
  • wordpress 添加字段seo点击排名软件哪家好
  • 北京专业网站开发公司网站百度收录
  • dede 网站名称 空的百度人工
  • 深圳网站系统找哪里十大网站平台
  • 查询网站空间百度推广登录平台官网