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

leetcode-10/6

1.最大子数组和【53】

找出具有最大和的连续子数组

思路:

        利用Kadane's Algorithm,一种解决最大子数组和的高效算法。用两个变量记录:

        一个记录以当前元素结尾的子数组和,该数组更新的时候,考虑要不要舍弃之前的和;另一个记录最大的子数组和

2. 前K个高频元素【347】

思想:

        先用哈希表将元素以及元素出现的次数存储起来;再通过堆排序,对元素出现次数进行排序,使得时间复杂度优于其它排序,优于O(nlogn)。

细节:(Java版)

        2.1.堆排序采用的排序方式是小顶堆,因为小顶堆的最顶部的元素存储的是值最小的,这样如果pop出去,就是小的值,留下来的就是前K个高频率的值;

        2.2.堆用优先级队列PriorityQueue实现,队列存储的是元素及元素出现次数的键值对,只不过排序的时候采用了Comparator排序器,然后用compare方法依据次数进行了排序;

        3.3.哈希表同时访问键值对用Entry,单独访问key就用entry.getKey(),访问value就用entry.getValue()

 for (Map.Entry<Integer, Integer> entry : occurrences.entrySet()) 

        3.4.最后返回结果的时候,由于小顶堆上面的元素值更小,如果返回要求按从大到小就得转一下顺序,不要求就直接返回


http://www.kler.cn/news/335372.html

相关文章:

  • UGUI(六大UI根基组件)
  • Spring Boot新闻推荐:实时数据处理
  • 【C++】二叉搜索树+变身 = AVL树
  • redo log 和 bin log 的两阶段提交
  • 【MySQL】MySQL 数据库主从复制详解
  • Qt QWidget控件
  • Spring Boot项目使用MyBatis Plus的详细步骤
  • Apache POI 2024/10/2
  • 【TypeScript学习】TypeScript基础学习总结一
  • 计算机前沿技术-人工智能算法-大语言模型-最新研究进展-2024-10-05
  • 在 Ubuntu 18.04 上安装 Syncthing
  • Mac通过ssh连接工具远程登录服务器( Royal TSX安装及使用)
  • sql-labs靶场第九关测试报告
  • GiliSoft Video Editor Pro专业视频编辑工具-视频剪辑/合并/字幕于一身的编辑器-供大家学习研究参考
  • 硬件面试(一)
  • JavaScript for循环语句
  • Spring Boot 2.1.6.RELEASE 中,javax.persistence缺失问题
  • Star 3w+,向更安全、更泛化、更云原生的 Nacos3.0 演进
  • Python 时间日期模块编码模板(时间日期对象基本操作、时间日期对象格式化与解析)
  • Java语法-类和对象之抽象类和接口