首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往
您找到你想要的搜索结果了吗?
是的
没有找到

[剑指offer] 二进制中1的个数

如果一个整数不为0,那么这个整数至少有一位是1。如果我们把这个整数减1,那么原来处在整数最右边的1就会变为0,原来在1后面的所有的0都会变成1(如果最右边的1后面还有0的话)。其余所有位将不会受到影响。 举个例子:一个二进制数1100,从右边数起第三位是处于最右边的一个1。减去1后,第三位变成0,它后面的两位0变成了1,而前面的1保持不变,因此得到的结果是1011.我们发现减1的结果是把最右边的一个1开始的所有位都取反了。这个时候如果我们再把原来的整数和减去1之后的结果做与运算,从原来整数最右边一个1那一位开始所有位都会变成0。如1100&1011=1000.也就是说,把一个整数减去1,再和原整数做与运算,会把该整数最右边一个1变成0.那么一个整数的二进制有多少个1,就可以进行多少次这样的操作。

02

从零编出一个区块链:在以太坊发布一个智能合约

区块链技术一大特点就是去中心化,由此衍生出一种基于区块链技术的云平台,在这些平台上你可以发布并执行自己的代码。与传统云计算平台例如亚马逊,阿里云不同的是,你在以太坊发布的代码不会存储在某一台主机上,不能像运行在阿里云,腾讯云那样的平台上的程序那样,你能把代码托管到一个具体对象,然后还能针对性的调试和修改,在以太坊发布代码后,二进制代码会存储在无数个独立的主机上,因此代码一旦发布就很难修改,如果你要对代码中的某些数据进行改动,那么以太坊需要广播给网络里面所有主机,由于数据修改非常麻烦,因此你发布的代码想要做变更时,你需要支付一定的代价。

01

Go WebAssembly 入门(一)

有关WebAssembly的介绍可以参考 几张图让你看懂WebAssembly 简单来说WebAssembly就是将其他语言C/Go/Rust等语言编译成wasm可执行二进制文件,浏览器来执行wasm。wasm相比JS,拥有体积更小,执行更快,因为最终编译成二进制文件,所以一些安全策略代码也更适合wasm。 经过尝试C和Go分别编写WebAssembly,相较而言我认为Go无论从语言层面还是工具链,用起来都更加方便一些。 本文使用原生go build,生成的wasm文件大约在1.4M左右,在生产环境中这个体积是很大的,优化go的wasm体积可以使用tinygo来build,同样的代码使用tinygo构建之后约为22K,甚至比C语言构建wasm的体积还要小(C语言 build后约为44K,不同版本不同环境可能略有差异)。参考https://tinygo.org/

02

扫码

添加站长 进交流群

领取专属 10元无门槛券

手把手带您无忧上云

扫码加入开发者社群

相关资讯

热门标签

活动推荐

    运营活动

    活动名称
    广告关闭
    领券