TypechoJoeTheme

Toasobi的博客

搜索到 19 篇与 的结果 ———
2023-10-03

每日温度(单调栈)

每日温度(单调栈)
题目:给定一个整数数组 temperatures ,表示每天的温度,返回一个数组 answer ,其中 answer[i] 是指对于第 i 天,下一个更高温度出现在几天后。如果气温在这之后都不会升高,请在该位置用 0 来代替。示例 1:输入: temperatures = [73,74,75,71,69,72,76,73]输出: [1,1,4,2,1,1,0,0]示例 2:输入: temperatures = [30,40,50,60]输出: [1,1,1,0]示例 3:输入: temperatures = [30,60,90]输出: [1,1,0]图解思路:点击此处跳转力扣图解代码如下:class Solution { public int[] dailyTemperatures(int[] temperatures) { int n = temperatures.length; int[] res = new int[n]; Stack<Integer> st = new Stack<>(); ...
2023-10-03

经典例题

0 阅读
4 评论
2023年10月03日
0 阅读
4 评论
2023-10-02

最大子序列的分数(优先队列)

最大子序列的分数(优先队列)
题目:给你两个下标从 0 开始的整数数组 nums1 和 nums2 ,两者长度都是 n ,再给你一个正整数 k 。你必须从 nums1 中选一个长度为 k 的 子序列 对应的下标。对于选择的下标 i0 ,i1 ,..., ik - 1 ,你的 分数 定义如下:nums1 中下标对应元素求和,乘以 nums2 中下标对应元素的 最小值 。用公式表示: (nums1[i0] + nums1[i1] +...+ nums1[ik - 1]) * min(nums2[i0] , nums2[i1], ... ,nums2[ik - 1]) 。请你返回 最大 可能的分数。一个数组的 子序列 下标是集合 {0, 1, ..., n-1} 中删除若干元素得到的剩余集合,也可以不删除任何元素。示例 1:输入:nums1 = [1,3,3,2], nums2 = [2,1,3,4], k = 3输出:12解释:四个可能的子序列分数为:选择下标 0 ,1 和 2 ,得到分数 (1+3+3) * min(2,1,3) = 7 。选择下标 0 ,1 和 3 ,得到分数 (1+3+2) * min(2,...
2023-10-02

经典例题

0 阅读
4 评论
2023年10月02日
0 阅读
4 评论
2023-09-27

寻找峰值(二分+爬坡)

寻找峰值(二分+爬坡)
题目:峰值元素是指其值严格大于左右相邻值的元素。给你一个整数数组 nums,找到峰值元素并返回其索引。数组可能包含多个峰值,在这种情况下,返回 任何一个峰值 所在位置即可。你可以假设 nums[-1] = nums[n] = -∞ 。你必须实现时间复杂度为 O(log n) 的算法来解决此问题。示例 1:输入:nums = [1,2,3,1]输出:2解释:3 是峰值元素,你的函数应该返回其索引 2。示例 2:输入:nums = [1,2,1,3,5,6,4]输出:1 或 5 解释:你的函数可以返回索引 1,其峰值元素为 2; 或者返回索引 5, 其峰值元素为 6。 爬坡法,如果右边的元素大于本元素,那么有一个高处就一定在右边,即右边一定有一个峰值,小于则同理同时爬坡法的遍历,还可以使用二分法进行优化,从而达到O(log n)的时间复杂度注意!在while (left <= right)中还要mid - 1和mid + 1的操作,所以我们需要处理越界问题lass Solution { public int findPeakElement(int[] nums) { ...
2023-09-27

经典例题

0 阅读
5 评论
2023年09月27日
0 阅读
5 评论
2023-09-25

数组中第K个最大元素(快速选择/优先队列、堆)

数组中第K个最大元素(快速选择/优先队列、堆)
题目:给定整数数组 nums 和整数 k,请返回数组中第 k 个最大的元素。请注意,你需要找的是数组排序后的第 k 个最大的元素,而不是第 k 个不同的元素。你必须设计并实现时间复杂度为 O(n) 的算法解决此问题。示例 1:输入: [3,2,1,5,6,4], k = 2输出: 5示例 2:输入: [3,2,3,1,2,4,5,5,6], k = 4输出: 4方法一:优先队列、堆PriorityQueue(优先队列)使用(需要定义比较器)底层数据结构是完全二叉树(最小堆),队列顶元素永远是最小元素,同时每次poll是移除并返回队顶元素。优先队列每次删除和添加都会调整堆,使得堆的所有节点的值小于等于子节点的值import java.util.Comparator; import java.util.PriorityQueue; public class Solution { public int findKthLargest(int[] nums, int k) { int len = nums.length; // 使用一个含有 k ...
2023-09-25

经典例题

0 阅读
4 评论
2023年09月25日
0 阅读
4 评论
2023-09-22

前缀树实现

前缀树实现
题目:Trie(发音类似 "try")或者说 前缀树 是一种树形数据结构,用于高效地存储和检索字符串数据集中的键。这一数据结构有相当多的应用情景,例如自动补完和拼写检查。请你实现 Trie 类:Trie() 初始化前缀树对象。void insert(String word) 向前缀树中插入字符串 word 。boolean search(String word) 如果字符串 word 在前缀树中,返回 true(即,在检索之前已经插入);否则,返回 false 。boolean startsWith(String prefix) 如果之前已经插入的字符串 word 的前缀之一为 prefix ,返回 true ;否则,返回 false 。示例:输入["Trie", "insert", "search", "search", "startsWith", "insert", "search"][[], ["apple"], ["apple"], ["app"], ["app"], ["app"], ["app"]]输出[null, null, true, false, true, n...
2023-09-22

经典例题

0 阅读
0 评论
2023年09月22日
0 阅读
0 评论

互动读者

  • zetsqqoayx闲逛

    评论 1 次 | 文章 0 篇

  • tlzchhypuy闲逛

    评论 1 次 | 文章 0 篇

  • nphgsldwac闲逛

    评论 1 次 | 文章 0 篇

  • myeledcbul闲逛

    评论 1 次 | 文章 0 篇