力扣每日一题:字符串中第二大的数字【思维模拟水题】

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

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

示例 1:

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

示例 2:

输入:s = "abc1111"
输出:-1
解释:出现在 s 中的数字只包含 [1] 。没有第二大的数字。

提示:

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

分析:给出的字符串是一个混合的,定义两个变量,fMax 便是最大值,sMax表示第二大值,我们遍历一遍,需要判断对应的字符c要在‘0’到‘9’之间if(c>='0'&&c<='9'),如果满足条件的话,然后我们在判断是否大于fMax ,if((c-'0')>fMax) ,满足条件的话,先fMax = sMax ,smax = c-'0' ,

如果不满足条件:判断c-‘0’ 是否满足(c-'0')<fMax&&(c-'0')>sMax 条件,如果满足的话,就赋值给第二大值 sMax = c-'0' ; 最后我们返回sMax就可以了

AC代码:

class Solution {
    public int secondHighest(String s) {
        int fMax = -1 ;
        int sMax = -1 ; 
        for(int i=0 ;i<s.length();i++){
            char c = s.charAt(i);
            if(c>='0'&&c<='9'){
                if((c-'0')>fMax){
                    sMax = fMax ; 
                    fMax = c-'0';

                }else  {
                    if((c-'0')<fMax&&(c-'0')>sMax){
                        sMax = c-'0' ; 
                    }
                }
            }
        }

        return sMax ; 
    }
}

猜你喜欢

转载自blog.csdn.net/weixin_54046648/article/details/128158547