跳至主要內容

1903-字符串中的最大奇数

daipeng大约 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);

    }