zoukankan      html  css  js  c++  java
  • Counting Bits

    Given a non negative integer number num. For every numbers i in the range 0 ≤ i ≤ num calculate the number of 1's in their binary representation and return them as an array.

    Example:
    For num = 5 you should return [0,1,1,2,1,2].

    Follow up:

    • It is very easy to come up with a solution with run time O(n*sizeof(integer)). But can you do it in linear time O(n) /possibly in a single pass?
    • Space complexity should be O(n).
    • Can you do it like a boss? Do it without using any builtin function like __builtin_popcount in c++ or in any other language.

    Hint:

    1. You should make use of what you have produced already.
    2. Divide the numbers in ranges like [2-3], [4-7], [8-15] and so on. And try to generate new range from previous.
    3. Or does the odd/even status of the number help you in calculating the number of 1s?

    Credits:
    Special thanks to @ syedee for adding this problem and creating all test cases.

    public class Solution {
        public int[] countBits(int num) {
            int[] res = new int[num+1];
            int pow = 1;
            res[0] = 0;
            for(int i=1,t=0;i<=num;i++,t++)
            {
                if(i==pow)
                {
                    pow = pow * 2;
                    t = 0;
                }
                res[i] = res[t] + 1;
                System.out.println(res[i]);
            }
            return res;
            
        }
    }

    reference: https://discuss.leetcode.com/topic/41785/simple-java-o-n-solution-using-two-pointers/3

  • 相关阅读:
    剑指 Offer 13. 机器人的运动范围
    32个触发事件XSS语句的总结
    CSS实现垂直居中的5种方法
    微信、QQ浏览器X5内核问题汇总
    值得关注的顶级开发者社区
    HTML5本地数据库(WebSQL)[转]
    按首字母排序汉字
    jQuery 源码中的 camelCase
    jQuery中的quickExpr
    手绘计划
  • 原文地址:https://www.cnblogs.com/hygeia/p/5706021.html
Copyright © 2011-2022 走看看