golang 统计uint64 数字二进制存储中1的数量

Posted barfoo

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了golang 统计uint64 数字二进制存储中1的数量相关的知识,希望对你有一定的参考价值。

package main

import (
    "fmt"
)

// pc[i] is the population count of i.
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))])
}

func AnalyzePopCount(x uint64) int {
    count := 0
    var i uint
    for i = 0; i < 8; i++ {
        tmpNum := x >> (i * 8)
        fmt.Printf("tmpNum: %v %x %b ", tmpNum, tmpNum, tmpNum)
        byteNum := byte(tmpNum)
        fmt.Printf("byteNum: %v %x %b count:%d ", byteNum, byteNum, byteNum, pc[byteNum])
        count += int(pc[byteNum])
    }
    return count
}

func main() {
    /*
        fmt.Println(2 << 1)
        fmt.Println(2<<1 + 1)
        fmt.Println(4 >> 1)
    */
    fmt.Println(pc[255])

    for i := range pc {
        fmt.Printf("%v, ", pc[i])
        if (i % 16) == 15 {
            fmt.Println()
        }
    }
    pc[0] = 255
    fmt.Println(pc[0])
    pc[0] = 254
    fmt.Println(pc[0])

    //fmt.Printf(" ")
    //fmt.Println(PopCount(23495631783903473))
    //fmt.Println(AnalyzePopCount(23495631783903473))
}






























































以上是关于golang 统计uint64 数字二进制存储中1的数量的主要内容,如果未能解决你的问题,请参考以下文章

golang 基础 —— 数据类型

golang 基础 —— 数据类型

Golang 基本类型

go笔记 - 字符串、数字、byte相互转换

使用 32 位无符号整数乘以 64 位数字的算法

在 GoLang 中将字节切片“[]uint8”转换为 float64