i think might making bit complicated. supposed pass in long, , return number of 1's in binary representation of number. negatives, return two's complement. have positives working, two's complement bit off. tips making work appreciated.
unsigned int binaryonescounter(long n) { unsigned int onecounter, negcounter; int binarystorage[63]; int index, negflag; onecounter = negflag = index = 0; int i; (i = 0; < 63; ++i) { binarystorage[i] = 0; } if(n < 0) { if (n == -1){ onecounter = 63 + 1; } else { /* negate , add 1*/ negflag = 1; n = (n * -1) + 1; } } while (n>=1) { if (n%2 == 1) { onecounter++; binarystorage[index] = 1; } else if (n%2 == 0) { binarystorage[index] = 0; } n = n/2; } if (negflag == 1 && n != 1) { negcounter = 64; onecounter = negcounter - onecounter; } return onecounter; }
it overcomplicated
int countones(long long i) { int nones = 0; unsigned long long *ptr = &i; while (*ptr) { nones += *ptr & 1; *ptr >>= 1; } return nones; }
ps -4 has 62 ones not 63 0b1111111111111111111111111111111111111111111111111111111111111100
here bit more universal 1 (counts in object)
int getbit(void *obj, size_t bit); size_t countbitsuniversal(void *obj, size_t osize) { size_t nones = 0, tmp = osize; osize <<= 3; if (osize && osize > tmp) { { nones += getbit(obj, --osize); } while (osize); } return nones; } int getbit(void *obj, size_t bit) { uint8_t *p = obj; return !!(p[bit >> 3] & (1 << (bit & 7))); } __________ usage example double x; printf("%zu\n", countbitsuniversal(&x, sizeof(x))); long long arr[100]; printf("%zu\n", countbitsuniversal(arr, sizeof(arr)));
Comments
Post a Comment