Jerring


  • 首页

  • 标签

  • 分类

  • 归档

LeetCode860-柠檬水找零

发表于 2019-06-26 | 分类于 LeetCode

题目链接

英文链接:https://leetcode.com/problems/lemonade-change/

中文链接:https://leetcode-cn.com/problems/lemonade-change/

题目详述

在柠檬水摊上,每一杯柠檬水的售价为 5 美元。

顾客排队购买你的产品,(按账单 bills 支付的顺序)一次购买一杯。

每位顾客只买一杯柠檬水,然后向你付 5 美元、10 美元或 20 美元。你必须给每个顾客正确找零,也就是说净交易是每位顾客向你支付 5 美元。

注意,一开始你手头没有任何零钱。

如果你能给每位顾客正确找零,返回 true ,否则返回 false 。

示例 1:

1
2
3
4
5
6
7
输入:[5,5,5,10,20]
输出:true
解释:
前 3 位顾客那里,我们按顺序收取 3 张 5 美元的钞票。
第 4 位顾客那里,我们收取一张 10 美元的钞票,并返还 5 美元。
第 5 位顾客那里,我们找还一张 10 美元的钞票和一张 5 美元的钞票。
由于所有客户都得到了正确的找零,所以我们输出 true。

示例 2:

1
2
输入:[5,5,10]
输出:true

示例 3:

1
2
输入:[10,10]
输出:false

示例 4:

1
2
3
4
5
6
7
输入:[5,5,10,10,20]
输出:false
解释:
前 2 位顾客那里,我们按顺序收取 2 张 5 美元的钞票。
对于接下来的 2 位顾客,我们收取一张 10 美元的钞票,然后返还 5 美元。
对于最后一位顾客,我们无法退回 15 美元,因为我们现在只有两张 10 美元的钞票。
由于不是每位顾客都得到了正确的找零,所以答案是 false。

提示:

  1. 0 <= bills.length <= 10000
  2. bills[i] 不是 5 就是 10 或是 20
阅读全文 »

LeetCode4-寻找两个有序数组的中位数

发表于 2019-06-26 | 分类于 LeetCode

题目链接

英文链接:https://leetcode.com/problems/median-of-two-sorted-arrays/

中文链接:https://leetcode-cn.com/problems/median-of-two-sorted-arrays/

题目详述

给定两个大小为 m 和 n 的有序数组 nums1 和 nums2。

请你找出这两个有序数组的中位数,并且要求算法的时间复杂度为 O(log(m + n))。

你可以假设 nums1 和 nums2 不会同时为空。

示例 1:

1
2
3
4
nums1 = [1, 3]
nums2 = [2]

则中位数是 2.0

示例 2:

1
2
3
4
nums1 = [1, 2]
nums2 = [3, 4]

则中位数是 (2 + 3)/2 = 2.5
阅读全文 »

LeetCode456-132模式

发表于 2019-06-26 | 分类于 LeetCode

题目链接

英文链接:https://leetcode.com/problems/132-pattern/

中文链接:https://leetcode-cn.com/problems/132-pattern/

题目详述

给定一个整数序列:a1, a2, …, an,一个132模式的子序列 ai, aj, ak 被定义为:当 i < j < k 时,ai < ak < aj。设计一个算法,当给定有 n 个数字的序列时,验证这个序列中是否含有132模式的子序列。

注意:n 的值小于15000。

示例1:

1
2
3
4
5
输入: [1, 2, 3, 4]

输出: False

解释: 序列中不存在132模式的子序列。

示例 2:

1
2
3
4
5
输入: [3, 1, 4, 2]

输出: True

解释: 序列中有 1 个132模式的子序列: [1, 4, 2].

示例 3:

1
2
3
4
5
输入: [-1, 3, 2, 0]

输出: True

解释: 序列中有 3 个132模式的的子序列: [-1, 3, 2], [-1, 3, 0] 和 [-1, 2, 0].
阅读全文 »

LeetCode475-供暖器

发表于 2019-06-26 | 分类于 LeetCode

题目链接

英文链接:https://leetcode.com/problems/heaters/

中文链接:https://leetcode-cn.com/problems/heaters/

题目详述

冬季已经来临。 你的任务是设计一个有固定加热半径的供暖器向所有房屋供暖。

现在,给出位于一条水平线上的房屋和供暖器的位置,找到可以覆盖所有房屋的最小加热半径。

所以,你的输入将会是房屋和供暖器的位置。你将输出供暖器的最小加热半径。

说明:

  1. 给出的房屋和供暖器的数目是非负数且不会超过 25000。
  2. 给出的房屋和供暖器的位置均是非负数且不会超过10^9。
  3. 只要房屋位于供暖器的半径内(包括在边缘上),它就可以得到供暖。
  4. 所有供暖器都遵循你的半径标准,加热的半径也一样。

示例 1:

1
2
3
输入: [1,2,3],[2]
输出: 1
解释: 仅在位置2上有一个供暖器。如果我们将加热半径设为1,那么所有房屋就都能得到供暖。

示例 2:

1
2
3
输入: [1,2,3,4],[1,4]
输出: 1
解释: 在位置1, 4上有两个供暖器。我们需要将加热半径设为1,这样所有房屋就都能得到供暖。
阅读全文 »

LeetCode84-柱状图中最大的矩形

发表于 2019-06-26 | 分类于 LeetCode

题目链接

英文链接:https://leetcode.com/problems/largest-rectangle-in-histogram/

中文链接:https://leetcode-cn.com/problems/largest-rectangle-in-histogram/

题目详述

给定 n 个非负整数,用来表示柱状图中各个柱子的高度。每个柱子彼此相邻,且宽度为 1 。

求在该柱状图中,能够勾勒出来的矩形的最大面积。

以上是柱状图的示例,其中每个柱子的宽度为 1,给定的高度为 [2,1,5,6,2,3]。

图中阴影部分为所能勾勒出的最大矩形面积,其面积为 10 个单位。

示例:

1
2
输入: [2,1,5,6,2,3]
输出: 10
阅读全文 »

LeetCode633-平方数之和

发表于 2019-06-25 | 分类于 LeetCode

题目链接

英文链接:https://leetcode.com/problems/sum-of-square-numbers/

中文链接:https://leetcode-cn.com/problems/sum-of-square-numbers/

题目详述

给定一个非负整数 c ,你要判断是否存在两个整数 a 和 b,使得 a^2 + b^2 = c。

示例1:

1
2
3
输入: 5
输出: True
解释: 1 * 1 + 2 * 2 = 5

示例2:

1
2
输入: 3
输出: False
阅读全文 »

LeetCode367-有效的完全平方数

发表于 2019-06-25 | 分类于 LeetCode

题目链接

英文链接:https://leetcode.com/problems/valid-perfect-square/

中文链接:https://leetcode-cn.com/problems/valid-perfect-square/

题目详述

给定一个正整数 num,编写一个函数,如果 num 是一个完全平方数,则返回 True,否则返回 False。

说明:不要使用任何内置的库函数,如 sqrt。

示例 1:

1
2
输入:16
输出:True

示例 2:

1
2
输入:14
输出:False
阅读全文 »

LeetCode42-接雨水

发表于 2019-06-25 | 分类于 LeetCode

题目链接

英文链接:https://leetcode.com/problems/trapping-rain-water/

中文链接:https://leetcode-cn.com/problems/trapping-rain-water/

题目详述

给定 n 个非负整数表示每个宽度为 1 的柱子的高度图,计算按此排列的柱子,下雨之后能接多少雨水。

上面是由数组 [0,1,0,2,1,0,1,3,2,1,2,1] 表示的高度图,在这种情况下,可以接 6 个单位的雨水(蓝色部分表示雨水)。 感谢 Marcos 贡献此图。

示例:

1
2
输入: [0,1,0,2,1,0,1,3,2,1,2,1]
输出: 6
阅读全文 »

LeetCode704-二分查找

发表于 2019-06-25 | 分类于 LeetCode

题目链接

英文链接:https://leetcode.com/problems/binary-search/

中文链接:https://leetcode-cn.com/problems/binary-search/

题目详述

给定一个 n 个元素有序的(升序)整型数组 nums 和一个目标值 target ,写一个函数搜索 nums 中的 target,如果目标值存在返回下标,否则返回 -1。

示例 1:

1
2
3
输入: nums = [-1,0,3,5,9,12], target = 9
输出: 4
解释: 9 出现在 nums 中并且下标为 4

示例 2:

1
2
3
输入: nums = [-1,0,3,5,9,12], target = 2
输出: -1
解释: 2 不存在 nums 中因此返回 -1

提示:

  1. 你可以假设 nums 中的所有元素是不重复的。
  2. n 将在 [1, 10000]之间。
  3. nums 的每个元素都将在 [-9999, 9999]之间。
阅读全文 »

LeetCode1095-山脉数组中查找目标值

发表于 2019-06-25 | 分类于 LeetCode

题目链接

英文链接:https://leetcode.com/problems/find-in-mountain-array/

中文链接:https://leetcode-cn.com/problems/find-in-mountain-array/

题目详述

(这是一个 交互式问题 )

给你一个 山脉数组 mountainArr,请你返回能够使得 mountainArr.get(index) 等于 target 最小 的下标 index 值。

如果不存在这样的下标 index,就请返回 -1。

所谓山脉数组,即数组 A 假如是一个山脉数组的话,需要满足如下条件:

首先,A.length >= 3

其次,在 0 < i < A.length - 1 条件下,存在 i 使得:

  • A[0] < A[1] < ... A[i-1] < A[i]
  • A[i] > A[i+1] > ... > A[A.length - 1]

你将 不能直接访问该山脉数组,必须通过 MountainArray 接口来获取数据:

  • MountainArray.get(k) - 会返回数组中索引为k 的元素(下标从 0 开始)
  • MountainArray.length() - 会返回该数组的长度

注意:

对 MountainArray.get 发起超过 100 次调用的提交将被视为错误答案。此外,任何试图规避判题系统的解决方案都将会导致比赛资格被取消。

为了帮助大家更好地理解交互式问题,我们准备了一个样例 “答案”:https://leetcode-cn.com/playground/RKhe3ave,请注意这 不是一个正确答案。

示例 1:

1
2
3
输入:array = [1,2,3,4,5,3,1], target = 3
输出:2
解释:3 在数组中出现了两次,下标分别为 2 和 5,我们返回最小的下标 2。

示例 2:

1
2
3
输入:array = [0,1,2,4,2,1], target = 3
输出:-1
解释:3 在数组中没有出现,返回 -1。

提示:

  1. 3 <= mountain_arr.length() <= 10000
  2. 0 <= target <= 10^9
  3. 0 <= mountain_arr.get(index) <= 10^9
阅读全文 »
1…141516…47
Jerring

Jerring

Talk is cheap, show me the code.

462 日志
4 分类
24 标签
© 2019 Jerring
由 Hexo 强力驱动
|
主题 — NexT.Muse v5.1.4