【每日一题Day169】LC1107负二进制转换 | 模拟进位 位运算

简介: 【每日一题Day169】LC1107负二进制转换 | 模拟进位 位运算

二进制转换【LC1107】

给你一个整数 n ,以二进制字符串的形式返回该整数的 **负二进制(base -2)**表示。

**注意,**除非字符串就是 "0",否则返回的字符串中不能含有前导零。

18分钟 挺满足了

image.png

class Solution {
    public String baseNeg2(int n) {
        if (n == 0) return "0";
        StringBuilder sb = new StringBuilder();
        int cnt = 0;
        while (n > 0 || cnt > 0){
            int num = n & 1;
            n = (n >> 1);
            int add = (num + cnt) % 2;            
            if (add == 1 && sb.length() % 2 == 1){
                cnt++;
            }
            sb.append(add); 
            cnt = (num + cnt) / 2;
        }
        return sb.reverse().toString();
    }
}

image.png

目录
相关文章
|
7月前
【每日一题Day202】LC1015可被 K 整除的最小整数 | 模运算
【每日一题Day202】LC1015可被 K 整除的最小整数 | 模运算
74 2
|
7月前
|
算法
【每日一题Day347】LC136只出现一次的数字 | 位运算
【每日一题Day347】LC136只出现一次的数字 | 位运算
51 0
|
7月前
|
算法
【每日一题Day349】LC260只出现一次的数字 III | 位运算
【每日一题Day349】LC260只出现一次的数字 III | 位运算
50 0
|
7月前
【每日一题Day268】LC415字符串相加 | 模拟
【每日一题Day268】LC415字符串相加 | 模拟
55 0
|
7月前
【每日一题Day210】LC1073负二进制数相加 | 模拟
【每日一题Day210】LC1073负二进制数相加 | 模拟
38 0
|
7月前
|
存储
【每日一题Day253】LC2两数相加 | 链表模拟
【每日一题Day253】LC2两数相加 | 链表模拟
30 0
|
7月前
【每日一题Day290】LC1281整数的各位积和之差 | 模拟
【每日一题Day290】LC1281整数的各位积和之差 | 模拟
48 0
|
7月前
【每日一题Day299】LC2235两整数相加
【每日一题Day299】LC2235两整数相加
33 0
|
7月前
【每日一题Day288】LC344反转字符串 | 双指针 位运算
【每日一题Day288】LC344反转字符串 | 双指针 位运算
34 0
|
算法 C++
剑指offer(C++)-JZ15:二进制中1的个数(算法-位运算)
剑指offer(C++)-JZ15:二进制中1的个数(算法-位运算)