题解 | #二进制取反#

二进制取反

https://www.nowcoder.com/practice/4ca47baf4d5f4417afc0f99d6efc7d42

import java.util.*;


public class Solution {
    /**
     * 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可
     *
     *
     * @param num string字符串
     * @return string字符串
     */
    public String maxLexicographical(String num) {
        // write code here
        StringBuilder sb = new StringBuilder(num);
        int len = num.length();
        for (int i = 0; i < len; i++) {
            if (num.charAt(i) == '0') {
                sb.setCharAt(i, '1');
            }
            //需要判断如果前面连续1,后面直到末尾为0的情况,否则i+1会数组越界
            if (i == len - 1) {
                break;
            }
            //当遇到出现01时需要停止
            if (num.charAt(i) == '0' && num.charAt(i + 1) == '1') {
                break;
            }
        }
        String ans = sb.toString();
        return ans;
    }
}

全部评论

相关推荐

01-07 11:46
Java
如图:也是让我遇到逆天公司了,实习生是按天给工资,不忙直接强制休假了
baskly:公司为北京超图软件股份有限公司武汉分公司,明年公司应该会招新实习生,刷到的小伙伴快跑
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务