给你一个混合字符串 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 ;
}
}