欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

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

 更新時間:2022年12月16日 15:34:49   作者:LetMeFly  
這篇文章主要為大家介紹了C++ LeetCode1796字符串中第二大數字示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪

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

力扣題目鏈接:leetcode.cn/problems/se…

給你一個混合字符串 s ,請你返回 s 中 第二大 的數字,如果不存在第二大的數字,請你返回 -1 。

混合字符串 由小寫英文字母和數字組成。

示例 1:

輸入:s = "dfa12321afd"
輸出: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

接著,用一個變量foundFirst來記錄是否已經找到了最大值,初始值為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 <= '9')
                bin[c - '0'] = true;
        }
        bool foundFirst = false;
        for (int i = 9; i >= 0; i--) {
            if (bin[i]) {
                if (foundFirst) {
                    return i;
                }
                else {
                    foundFirst = true;
                }
            }
        }
        return -1;
    }
};

以上就是C++ LeetCode1796字符串中第二大數字的詳細內容,更多關于C++ 字符串第二大數字示例的資料請關注腳本之家其它相關文章!

相關文章

  • C++實現考勤管理系統(tǒng)

    C++實現考勤管理系統(tǒng)

    這篇文章主要介紹了C++實現考勤管理系統(tǒng),文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-03-03
  • C++中的std::initializer_list使用解讀

    C++中的std::initializer_list使用解讀

    這篇文章主要介紹了C++中的std::initializer_list使用,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-07-07
  • Qt掃盲篇之QRegularExpression正則匹配總結

    Qt掃盲篇之QRegularExpression正則匹配總結

    QRegularExpression是Qt5.0引進的,修復了很多bug,提高了效率,使用時建議使用QRegularExpression,下面這篇文章主要給大家介紹了關于Qt掃盲篇之QRegularExpression正則匹配的相關資料,需要的朋友可以參考下
    2023-03-03
  • C++11新特性之變長參數模板詳解

    C++11新特性之變長參數模板詳解

    本文主要介紹了C++11變長參數模板,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2021-08-08
  • C語言內存分布與heap空間分別詳細講解

    C語言內存分布與heap空間分別詳細講解

    一個程序本質上都是由 BSS 段、data段、text段三個組成的。這種概念在當前的計算機程序設計中是非常重要的一個基本概念,并且在嵌入式系統(tǒng)的設計中也非常重要,牽涉到嵌入式系統(tǒng)執(zhí)行時的內存大小分配,存儲單元占用空間大小的問題
    2022-11-11
  • C++內存對齊的實現

    C++內存對齊的實現

    本文主要介紹了C++內存對齊的實現,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2023-02-02
  • C語言代碼實現掃雷小游戲

    C語言代碼實現掃雷小游戲

    這篇文章主要為大家詳細介紹了C語言代碼實現掃雷小游戲,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2020-02-02
  • Linux下g++編譯與使用靜態(tài)庫和動態(tài)庫的方法

    Linux下g++編譯與使用靜態(tài)庫和動態(tài)庫的方法

    下面小編就為大家?guī)硪黄狶inux下g++編譯與使用靜態(tài)庫和動態(tài)庫的方法。小編覺得挺不錯的,現在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-05-05
  • 四個例子說明C語言?全局變量

    四個例子說明C語言?全局變量

    這篇文章主要介紹了四個例子說明C語言?全局變量,全局變量是C語言語法和語義中一個很重要的知識點,首先它的存在意義需要從三個不同角度去理解,下面來看看這三個不同的內容分別是什么吧
    2022-04-04
  • 基于C語言實現泛型編程詳解

    基于C語言實現泛型編程詳解

    對于C而言,想實現泛型編程并非易事,甚至可以說非常繁瑣,一大堆坑。最主要也沒有現成的輪子可用。本文就來詳細為大家講講C語言如何實現泛型編程詳解,需要的可以參考一下
    2022-07-07

最新評論