• [LeetCode] Find Smallest Letter Greater Than Target


    Given a list of sorted characters letters containing only lowercase letters, and given a target letter target, find the smallest element in the list that is larger than the given target.

    Letters also wrap around. For example, if the target is target = 'z' and letters = ['a', 'b'], the answer is 'a'.

    Examples:

    Input:
    letters = ["c", "f", "j"]
    target = "a"
    Output: "c"
    
    Input:
    letters = ["c", "f", "j"]
    target = "c"
    Output: "f"
    
    Input:
    letters = ["c", "f", "j"]
    target = "d"
    Output: "f"
    
    Input:
    letters = ["c", "f", "j"]
    target = "g"
    Output: "j"
    
    Input:
    letters = ["c", "f", "j"]
    target = "j"
    Output: "c"
    
    Input:
    letters = ["c", "f", "j"]
    target = "k"
    Output: "c"

    Note:

    1. letters has a length in range [2, 10000].
    2. letters consists of lowercase letters, and contains at least 2 unique letters.
    3. target is a lowercase letter.

    找出比目标值大的最小的那个字母

    给定一个字符数组,找出比目标值大的最小的那个字符,如果目标值大于数组中最大的字母,则返回数组中第一个字母。

    使用upper_bound()这个函数找出比目标字母大的那个数,这时需要判断

    如果目标值大于等于数组中最大的字母,则返回数组中的首字母。

    否则返回找到的那个字母。

    class Solution {
    public:
        char nextGreatestLetter(vector<char>& letters, char target) {
            auto it = upper_bound(letters.begin(), letters.end(), target);
            if (it == letters.end())
                return letters.front();
            else {
                return *it;
            }
        }
    };
    // 12 ms

    也可以使用二分搜索。

    class Solution {
    public:
        char nextGreatestLetter(vector<char>& letters, char target) {
            if (letters.back() <= target)
                return letters.front();
            int left = 0, right = letters.size() - 1;
            while (left < right)  {
                int mid = left + (right - left) / 2;
                if (letters[mid] > target) {
                    right = mid;
                }
                else {
                    left = mid + 1;
                }
            }
            return letters[left];
        }
    };
  • 相关阅读:
    MySQL集群搭建(4)-MMM+LVS+Keepalived
    MySQL集群搭建(3)-MMM高可用架构
    MySQL集群搭建(2)-主主从模式
    MySQL集群搭建(1)-主备搭建
    MySQL 安装(二进制版)
    Nginx缓存了DNS解析造成后端不通--代理
    开启tcp_timestamps和tcp_tw_recycle造成NAT转发连接不上
    tcp_tw_recycle参数引发的故障
    记一次TIME_WAIT网络故障
    TCP服务端收到syn但是不回复syn ack问题分析
  • 原文地址:https://www.cnblogs.com/immjc/p/8027263.html
Copyright © 2020-2023  润新知