0
点赞
收藏
分享

微信扫一扫

LeetCode简单题之字符串中的最大奇数

往复随安_5bb5 2022-02-08 阅读 41

题目

给你一个字符串 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]

在这里插入图片描述

举报

相关推荐

0 条评论