题解 | #二进制取反#

二进制取反

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

全部评论

相关推荐

程序员花海:实习和校招简历正确格式应该是教育背景+实习+项目经历+个人评价 其中项目经历注意要体现业务 实习经历里面的业务更是要自圆其说 简历模板尽可能保持干净整洁 不要太花哨的
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

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