Go 种群统计

种群统计:返回一个数字中被置位的个数(值为1)

package popcount

var pc [256]byte

func init() {
    for i := range pc {
        pc[i] = pc[i/2] + byte(i&1)
    }
}

func PopCount(x uint64) int {
    return int(pc[byte(x>>(0*8))] +
        pc[byte(x>>(1*8))] +
        pc[byte(x>>(2*8))] +
        pc[byte(x>>(3*8))] +
        pc[byte(x>>(4*8))] +
        pc[byte(x>>(5*8))] +
        pc[byte(x>>(6*8))] +
        pc[byte(x>>(7*8))])
}

2.3 使用循环重写PopCount来代替单个表达式

func PopCount(x uint64) int {
    var n = 0
    for i := uint(0); i < 8; i++ {
        n += int(pc[byte(x>>(i*8))])
    }
    return n
}

2.4 写一个用于统计位的PopCount, 它在其实际参数的64位上执行移位操作,每次判断最右边的位,进面实现统计功能

func PopCount(x uint64) int {
    var n = 0
    for i := uint(0); i < 64; i++ {
        n += int((x >> i) & 1)
    }
    return n
}

2.5 使用x&(x-1)可以清除x最右边的非零位,利用该特点写一个PopCount

func PopCount(x uint64) int {
    var n = 0
    for x != 0 {
        x = x & (x - 1)
        n++
    }
    return n
}

你可能感兴趣的:(Go 种群统计)