题解 | #二进制取反#

二进制取反

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;
    }
}

全部评论

相关推荐

双飞鼠鼠不会梦到大厂offer:就说课很少并且导员鼓励出来实习
点赞 评论 收藏
分享
钟情于风TuT:世另我
点赞 评论 收藏
分享
点赞 收藏 评论
分享
牛客网
牛客企业服务