目录
1. 题目描述
给你一个排序后的字符列表 letters
,列表中只包含小写英文字母。另给出一个目标字母 target
,请你寻找在这一有序列表里比目标字母大的最小字母。
在比较时,字母是依序循环出现的。举个例子:
- 如果目标字母
target = 'z'
并且字符列表为letters = ['a', 'b']
,则答案返回'a'
示例 1:
输入: letters = ["c", "f", "j"],target = "a" 输出: "c"
示例 2:
输入: letters = ["c","f","j"], target = "c" 输出: "f"
示例 3:
输入: letters = ["c","f","j"], target = "d" 输出: "f"
提示:
2 <= letters.length <= 10^4
letters[i]
是一个小写字母letters
按非递减顺序排序letters
最少包含两个不同的字母target
是一个小写字母
来源:力扣(LeetCode)
链接:https://leetcode-cn.com/problems/find-smallest-letter-greater-than-target
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。
2. 解题分析
二分法搜索。
在二分搜索之前,先判断最末尾一个字符大于target,如果是的话,则取letters[0];否则,进行二分法搜索。
3. 代码实现
class Solution:
def nextGreatestLetter(self, letters: List[str], target: str) -> str:
if letters[-1] <= target:
return letters[0]
# Bisection search
L = len(letters)
left,right = 0,L-1
while True:
#print(left,right)
if left==right:
return letters[left]
elif left == right - 1:
return letters[left] if letters[left]>target else letters[right]
middle = (left+right)//2
if target < letters[middle]:
right = middle
else:
left = middle
执行用时:40 ms, 在所有 Python3 提交中击败了55.64%的用户
内存消耗:17.2 MB, 在所有 Python3 提交中击败了5.59%的用户