本文主要是介绍LeetCode 2864.最大二进制奇数:贪心(C++/Python的两行构造),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
【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 1
- 尽可能大:所有 1 1 1尽可能靠前
因此统计一下字符串s
中有多少个 1 1 1(假设有cnt1
个),那么“cnt1 - 1
个1
、len(s) - cnt1
个0
、1
个1
”组成的字符串即为最大奇二进制字符串。
- 时间复杂度 O ( N 2 ) O(N^2) O(N2)
- 空间复杂度 O ( N log N ) O(N\log N) O(NlogN)
AC代码
C++
class Solution {
public:string maximumOddBinaryNumber(string s) {int cnt1 = count(s.begin(), s.end(), '1');return string(cnt1 - 1, '1') + string(s.size() - cnt1, '0') + '1';}
};
Python
class Solution:def maximumOddBinaryNumber(self, s: str) -> str:cnt1 = sum(1 if c == '1' else 0 for c in s)return '1' * (cnt1 - 1) + '0' * (len(s) - cnt1) + '1'
同步发文于CSDN和我的个人博客,原创不易,转载经作者同意后请附上原文链接哦~
Tisfy:https://letmefly.blog.csdn.net/article/details/136669293
这篇关于LeetCode 2864.最大二进制奇数:贪心(C++/Python的两行构造)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!