题目
给你一个字符串 num ,表示一个大整数。请你在字符串 num 的所有 非空子字符串 中找出 值最大的奇数 ,并以字符串形式返回。如果不存在奇数,则返回一个空字符串 “” 。
子字符串 是字符串中的一个连续的字符序列。
示例 1:
输入:num = “52”
输出:“5”
解释:非空子字符串仅有 “5”、“2” 和 “52” 。“5” 是其中唯一的奇数。
示例 2:
输入:num = “4206”
输出:""
解释:在 “4206” 中不存在奇数。
示例 3:
输入:num = “35427”
输出:“35427”
解释:“35427” 本身就是一个奇数。
提示:
1 <= num.length <= 10^5
num 仅由数字组成且不含前导零
来源:力扣(LeetCode)
解题思路
最大的奇数一定是最“长”的数,这个数应该符合个位为奇数然后最高位不为0,所以我们可以定义两个指针分别从前面判断是否是0,从后边判断是否是1,3,5,7,9,然后返回最长的数即可。
class Solution:
def largestOddNumber(self, num: str) -> str:
i=0
j=len(num)-1
while int(num[j])%2==0 and j>=i: #从后边寻找个位数
j-=1
while int(num[i])==0 and i<j: #从前面寻找不为0的数
i+=1
return num[i:j+1]