【每日一题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

目录
相关文章
|
6月前
【每日一题Day202】LC1015可被 K 整除的最小整数 | 模运算
【每日一题Day202】LC1015可被 K 整除的最小整数 | 模运算
66 2
|
6月前
|
算法
【每日一题Day347】LC136只出现一次的数字 | 位运算
【每日一题Day347】LC136只出现一次的数字 | 位运算
49 0
|
6月前
|
算法
【每日一题Day349】LC260只出现一次的数字 III | 位运算
【每日一题Day349】LC260只出现一次的数字 III | 位运算
44 0
|
6月前
【每日一题Day210】LC1073负二进制数相加 | 模拟
【每日一题Day210】LC1073负二进制数相加 | 模拟
34 0
|
6月前
【每日一题Day268】LC415字符串相加 | 模拟
【每日一题Day268】LC415字符串相加 | 模拟
46 0
|
6月前
|
存储
【每日一题Day253】LC2两数相加 | 链表模拟
【每日一题Day253】LC2两数相加 | 链表模拟
24 0
|
6月前
【每日一题Day290】LC1281整数的各位积和之差 | 模拟
【每日一题Day290】LC1281整数的各位积和之差 | 模拟
41 0
|
6月前
【每日一题Day299】LC2235两整数相加
【每日一题Day299】LC2235两整数相加
31 0
|
算法 C++
剑指offer(C++)-JZ56:数组中只出现一次的两个数字(算法-位运算)
剑指offer(C++)-JZ56:数组中只出现一次的两个数字(算法-位运算)
剑指offer(C++)-JZ56:数组中只出现一次的两个数字(算法-位运算)
|
算法 C++
剑指offer(C++)-JZ65:不用加减乘除做加法(算法-位运算)
剑指offer(C++)-JZ65:不用加减乘除做加法(算法-位运算)