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

目录
相关文章
|
2天前
|
算法
【每日一题Day347】LC136只出现一次的数字 | 位运算
【每日一题Day347】LC136只出现一次的数字 | 位运算
31 0
|
2天前
|
算法
【每日一题Day349】LC260只出现一次的数字 III | 位运算
【每日一题Day349】LC260只出现一次的数字 III | 位运算
23 0
|
2天前
【每日一题Day210】LC1073负二进制数相加 | 模拟
【每日一题Day210】LC1073负二进制数相加 | 模拟
16 0
|
2天前
【每日一题Day290】LC1281整数的各位积和之差 | 模拟
【每日一题Day290】LC1281整数的各位积和之差 | 模拟
17 0
|
2天前
【每日一题Day268】LC415字符串相加 | 模拟
【每日一题Day268】LC415字符串相加 | 模拟
29 0
|
2天前
|
存储
【每日一题Day253】LC2两数相加 | 链表模拟
【每日一题Day253】LC2两数相加 | 链表模拟
16 0
|
2天前
【每日一题Day127】LC1238循环码排列 | 格雷码构造 位运算
【每日一题Day127】LC1238循环码排列 | 格雷码构造 位运算
29 0
【每日一题Day127】LC1238循环码排列 | 格雷码构造 位运算
|
2天前
【每日一题Day299】LC2235两整数相加
【每日一题Day299】LC2235两整数相加
19 0
|
10月前
|
算法
《零基础学算法》(第二讲)进制转换
《零基础学算法》(第二讲)进制转换
56 0
|
7月前
|
算法 C++
剑指offer(C++)-JZ15:二进制中1的个数(算法-位运算)
剑指offer(C++)-JZ15:二进制中1的个数(算法-位运算)