2864.最大二进制奇数
【LetMeFly】2864.最大二进制奇数:贪心(C++/Python的两行构造)
力扣题目链接:https://leetcode.cn/problems/maximum-odd-binary-number/
给你一个 二进制 字符串 s
,其中至少包含一个 '1'
。
你必须按某种方式 重新排列 字符串中的位,使得到的二进制数字是可以由该组合生成的 最大二进制奇数 。
以字符串形式,表示并返回可以由给定组合生成的最大二进制奇数。
注意 返回的结果字符串 可以 含前导零。
示例 1:
输入:s = "010" 输出:"001" 解释:因为字符串 s 中仅有一个 '1' ,其必须出现在最后一位上。所以答案是 "001" 。
示例 2:
输入:s = "0101" 输出:"1001" 解释:其中一个 '1' 必须出现在最后一位上。而由剩下的数字可以生产的最大数字是 "100" 。所以答案是 "1001" 。
提示:
1 <= s.length <= 100
s
仅由'0'
和'1'
组成s
中至少包含一个'1'
方法一:贪心
两个条件:
- 奇数:最后一位二进制为$1$
- 尽可能大:所有$1$尽可能靠前
因此统计一下字符串s
中有多少个$1$(假设有cnt1
个),那么“cnt1 - 1
个1
、len(s) - cnt1
个0
、1
个1
”组成的字符串即为最大奇二进制字符串。
- 时间复杂度$O(N^2)$
- 空间复杂度$O(N\log N)$
AC代码
C++
1 |
|
Python
1 |
|
同步发文于CSDN和我的个人博客,原创不易,转载经作者同意后请附上原文链接哦~
Tisfy:https://letmefly.blog.csdn.net/article/details/136669293
2864.最大二进制奇数
https://blog.letmefly.xyz/2024/03/13/LeetCode 2864.最大二进制奇数/