Welcome to collectivesolver - Programming & Software Q&A. A website you can trust. All programs tested and work.

aviboots(AT)netvision.net.il

Instant Grammar Checker - Correct all grammar errors and enhance your writing
BlueHost Web Hosting

Profollica™ is a standout product in the hair regrowth industry.

New Arrival!  Shop NOW for metal eyeglasses at GlassesShop.com!

Bonsai Boy of New York Bonsai Trees and Accessories

DreamCloud The Comfortable Luxury Mattress Ecommerce Software - Best Ecommerce Platform Made for You - Free Trial

DreamHost Web Hosting


Liquid Web Cloud VPS Hosting

Disclosure We are a professional Programming & Software Q&A website, that receives compensation from some of the links whose we show you with Information. It means that my content may contain affiliate links.

13,696 questions

18,622 answers

573 users

How to count the total set bits in all numbers from 1 to N in C

1 Answer

0 votes
#include <stdio.h> 
  
unsigned int count_set_bits(unsigned int n) { 
    unsigned int count = 0; 
    while (n) { 
        count += n & 1; 
        n >>= 1; 
    } 
    return count; 
}  

unsigned int count_total_set_bits(unsigned int n) { 
    int setBitCount = 0; 
  
    for (int i = 1; i <= n; i++) 
        setBitCount += count_set_bits(i); 
  
    return setBitCount; 
} 

int main() 
{ 
    int n = 6; 
    /*
        0001
        0010
        0011
        0100
        0101
        0110
    */
    
    printf("%i", count_total_set_bits(n)); 
    
    return 0; 
} 



/*
run:

9

*/

 




answered Apr 12, 2019 by avibootz
edited Apr 12, 2019 by avibootz
...