1903-字符串中的最大奇数
大约 1 分钟
给你一个字符串 num ,表示一个大整数。请你在字符串 num 的所有 非空子字符串 中找出 值最大的奇数 ,并以字符串形式返回。如果不存在奇数,则返回一个空字符串 "" 。
子字符串 是字符串中的一个连续的字符序列。
示例 1:
输入:num = "52"
输出:"5"
解释:非空子字符串仅有 "5"、"2" 和 "52" 。"5" 是其中唯一的奇数。
示例 2:
输入:num = "4206"
输出:""
解释:在 "4206" 中不存在奇数。
示例 3:
输入:num = "35427"
输出:"35427"
解释:"35427" 本身就是一个奇数。
提示:
1 <= num.length <= 105
num 仅由数字组成且不含前导零
来源:力扣(LeetCode)
链接:https://leetcode.cn/problems/largest-odd-number-in-string
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。
对于本题来说,值最大的奇数就是位数最长的奇数,我们倒序遍历,找到奇数数字后即找到了相应的最大的奇数。 同时注意num不含前导0,这样我们不用做额外的处理。
public String largestOddNumber(String num) {
int idx = num.length() - 1;
while (idx >= 0) {
if ((num.charAt(idx) - '0') % 2 == 1) {
break;
}
idx--;
}
if (idx < 0) {
return "";
}
return num.substring(0, idx + 1);
}