在某些特殊运算中,不想通过逻辑代码来判断某个数是负整数还是正整数,首先我们想到的取正还是负最好的方式就是把那数换算成正负1,通过思考发现用简单的X除以X不通满足条件,虽然正数除以正数=0,但是当X为负数或0时就出问题了。
在此我想到了用移位运算,一个简单的公式: 数字类型>> 数字类型的最大位数-1|1 (带符号右移再取或)
比如:100,我们要得到1。因为100是int类型,int类型占32位(有些是64位,这得跟计算机有关),
100>>31|1,计算结果就是1.
在某些特殊运算中,不想通过逻辑代码来判断某个数是负整数还是正整数,首先我们想到的取正还是负最好的方式就是把那数换算成正负1,通过思考发现用简单的X除以X不通满足条件,虽然正数除以正数=0,但是当X为负数或0时就出问题了。
在此我想到了用移位运算,一个简单的公式: 数字类型>> 数字类型的最大位数-1|1 (带符号右移再取或)
比如:100,我们要得到1。因为100是int类型,int类型占32位(有些是64位,这得跟计算机有关),
100>>31|1,计算结果就是1.