开发者

C++ LeetCode1796字符串中第二大数字

开发者 https://www.devze.com 2022-12-17 10:50 出处:网络 作者: LetMeFly
目录LeetCode 1796.字符串中第二大的数字方法一:遍历题目分析解题思路复杂度分析AC代码C++LeetCode 1796.字符串中第二大的数字
目录
  • LeetCode 1796.字符串中第二大的数字
  • 方法一:遍历
    • 题目分析
    • 解题思路
    • 复杂度分析
  • AC代码
    • C++

LeetCode 1796.字符串中第二大的数字

力扣题目链接:leetcode.cn/problems/se…

给你一个混合字符串 s ,请你返回 s 中 第二大 的数字,如果不存在第二大的数字,请你返回 -1 。

混合字符串 由小写英文字母和数字组成。

示例 1:

输入:s = "d开发者_JAVA教程f编程客栈a12321afd"

输出:2

解释:出现在 s 中的数字包括 [1, 2, 3] 。第二大的数字是 2 。

示例 2:

输入:s = "abc1111"

输出:-1

解释:出现在 s 中的数字只包含 [1] 。没有第二大的数字。

提示:

  • 1 <= s.length <= 500
  • s 只包含小写英文字母和(或)数字。

方法一:遍历

题目分析

题目中说的“第二编程大”数字,到底什么是第二大?英文原文是“Second largest”

也就是说,是从大到小第二个数,不是从小到大第二个数。

样例中“123”,不论是从小到大还是从大到小都是“2”,不如把样例换成“1234”,这样答案是“3”,就一目了然了。

解题思路

首先开辟一个大小为“10”的布尔数组,初始值为false

接着遍历字符串,如果字符串的某个字符是数字,那么就将对应的那个布尔值标记为true

接着,用一个变量f编程客栈oundFirst来记录是否已经找到了最大值,初始值为false

90遍历布尔数组,如果遇到某个值为true,就看foundFirst是否已经为true

  • 如果为true,就返回当前的对应元素
  • 否则,将foundFirst标记为true

若遍历结束后仍未找到“第二大数”,那么就返回-1

复杂度分析

  • 时间复杂度O(len(s))
  • 空间复杂度O(C),这里C=10,也可以理解为O(1)

AC代码

C++

class Solution {
public:
    int secondHighest(string& s) {
        bool bin[10] = {false};
        for (char c : s) {
            if (c >= '0' && c <=python '9')
                bin[c - '0'] = true;
        }
        bool foundFirst = false;
        for (int i = 9; i >= 0; i--) {
            if (bin[i]) {
                if (foundFirst) {
                    return i;
                }
             python   else {
                    foundFirst = true;
                }
            }
        }
        return -1;
    }
};

以上就是C++ LeetCode1796字符串中第二大数字的详细内容,更多关于C++ 字符串第二大数字示例的资料请关注我们其它相关文章!

0

精彩评论

暂无评论...
验证码 换一张
取 消

关注公众号