JS位运算和遍历
JS位运算符
整数
- 有符号整数:允许使用正数和负数,第32位作为符号位,前31位才是存储位
- 无符号整数:只允许用正数
- 如果用
n
代表位 位数 = 2^n-1
- 由于位数(1、2、4、8、16...)中只有第一位
| 1 |
是奇数,所以可以根据第一位| 1 |
的数值判断一个数值是奇数还是偶数 num % 2
运算本质就是取的| 1 |
的值,如果是1就是奇数,是0就是偶数
补码和反码
- 确定该数字的非负版本的二级制表示
const getBinary = num => num.toString(2)
- 求得二进制反码,反码就是把原来的二进制1,0互换。即要把 0 替换为 1,把 1 替换为 0
- 在二进制反码上加1
位运算NOT~
~
的处理过程
- 把运算数转换成32位数字
- 把二进制数转换成它的二进制反码
- 把二进制数转换成浮点数
实质上是对数字求负,然后减1-num - 1
位运算AND &
和 OR |
和 XOR ^
&
每个数字中的数位对齐,位对位进行与运算|
每个数字中的数位对齐,位对位进行或运算^
每个数字中的数位对齐,位对位进行异或运算- JS中的二进制有32位,所以要进行32次运算
有符号移动<<< 、>>>
和无符号移动 <<、>>
- 有符号移动在移动的时候不会移动符号位,即不会移动第32位,而无符号移动会移动符号位
- 左移
<<
相等于乘于2,而右移>>
相当于除于2
遍历二进制位结构
由于二进制的结构是| 16 | 8 | 4 | 2 | 1 |
这种结构,位数是从右边开始的,我们遍历要从右边开始
function eachBit(num, callback) {
while (num) {
num >>= 1
}
}
- 这里使用了右移的方式遍历,当num为0的时候就停止遍历如
10 = (0,1,0,1,0)
,最靠近左边的1
在第四位2^4-1 = 8
,| 8 |
,所以遍历了4次 - 我们要把
遍历的次数
和当前的位数
以及被右移出去的值(0或1)
传递给callback
function eachBit(num, callback) {
let i = 0
let bitNum = 0
while (num) {
// 奇偶位或第一位的值,也即即将被右移出去的值
const value = num % 2
// 位数 = 2^i
bitNum = Math.pow(2, i)
callback && callback(value, i, bitNum)
// 右移1位
num >>= 1
i++
}
}
使用遍历体实现字符串repeat函数
function repeat(str, n) {
let res = ''
eachBit(n, v => {
if (v === 1) {
res += str
}
if (n > 1) {
str += str
}
})
return res
}
- 实现思路:由于字符串要重复的内容是一样的,为了减少遍历次数,采用了
eachBit
,比如n = 10
那么二进制'1010'
只需遍历四次 - 注意上面的1对应的数字,第四位1对应
| 8 |
,第二位1对应| 2 |
str += str
就是一直迭代,重复次数是2^n
(n是遍历的次数)v === 1
的时候也即| 2 |
,这时候是str + str
2个重复的str
,| 8 |
是8个重复的str
- 也即
str
的重复次数是对应| 2 |
和| 8 |
的,刚好重复10次 n > 1
是n等于1,没有必要再执行迭代了,只会遍历一次,且v必等于1,后面没有必要执行了
JS位运算和遍历的更多相关文章
- js位运算-按位非
正数 取得二进制表示 取反(发现符号位是1,表示负数) 符号位不变,其余位取反 取反后加一 负数 取得负数的二进制表示(即绝对值的二进制反码加一) 取反即可
- js中的位运算
按位运算符是把操作数看作一系列单独的位,而不是一个数字值.所以在这之前,不得不提到什么是"位": 数值或字符在内存内都是被存储为0和 1的序列,每个0和1被称之为1个位,比如说10 ...
- js中位运算的运用
原文:js中位运算的运用 我们可能很少在编程中用位运算,如果没深入学习,可能也很难理解.平时的数值运算,其实是要先转换成二进制再进行运算的,而位运算就是直接进行二进制运算,所以位运算的执行效率肯定是更 ...
- 深入研究js中的位运算及用法
什么是位运算? 位运算是在数字底层(即表示数字的 32 个数位)进行运算的.由于位运算是低级的运算操作,所以速度往往也是最快的(相对其它运算如加减乘除来说),并且借助位运算有时我们还能实现更简单的程序 ...
- Java 位运算2-LeetCode 201 Bitwise AND of Numbers Range
在Java位运算总结-leetcode题目博文中总结了Java提供的按位运算操作符,今天又碰到LeetCode中一道按位操作的题目 Given a range [m, n] where 0 <= ...
- js赋值运算的理解
简介 js引擎由于为了效率,很多时候的非直接量赋值都不是copy一份在赋值给新的变量,而是一个引用 ps:直接量:直接值数字字符串等 为什么使用len = doms.length; 里的len效率要比 ...
- 【位运算经典应用】 N皇后问题
说到位运算的经典应用,不得不说N皇后问题. 学过程序设计的都知道N皇后问题,没听过也没关系.很简单,最传统的的N皇后问题是这个样子的,给你一个n * n大小的board,让你放n个皇后(国际象棋),要 ...
- javascript的变态位运算
javascript的变态位运算 var a = "10" | 0; alert(a); alert (typeof a);结果为10,number. 这就是说这条语句可以将字符串 ...
- Gym 100818I Olympic Parade(位运算)
Olympic Parade http://acm.hust.edu.cn/vjudge/contest/view.action?cid=101594#problem/I [题意]: 给出N个数,找出 ...
随机推荐
- day16正则表达式作业详解
1.正则表达式练习题 点击查看详细内容 作业的讲解 1.匹配整数或者小数(包括正数和负数) -?\d+.\d+|-?\d+ -?\d+(\.\d+)? 2.匹配年月日日期 格式2018-12-6 #找 ...
- Codeforces 350D(计算几何)
要点 用A.B.C一般式确定每条直线 将合法的圆心中点存到每条直线所属的vector中 枚举所有线段,二分后\(O(1)\)得到其中存在多少答案,累加 #include <cstdio> ...
- js:数组里面获取键名和键值
在写php时用ajax异步传回的返回数组时是json格式,在js里面处理时有时需要用到键名,此时可以用in来处理 js只有数字索引: <script> var data = new arr ...
- Oracle存储过程语法及编译过程讲解
语法 ? 1 2 3 4 5 6 7 8 9 10 CREATE [ORReplace]PROCEDURE[schema.] procedure_name [(argument [{IN|OUT|IN ...
- 【SQL Server 优化性能的几个方面】(转)
转自:http://blog.csdn.net/feixianxxx/article/details/5524819 SQL Server 优化性能的几个方面 (一).数据库的设计 可以参看最 ...
- spark shell start
spark-shell \--master yarn \--deploy-mode client \--queue default \--driver-memory 1G \--executor-me ...
- string的各种函数(系统学习)
1.按照面向对象的要求,可以把字符串看作一个对象,设计一个串类加以描述.但是,在一般的情况下不必建立自己的串类,c++标准 在库<string>中给出了类string,提供了丰富的串操作, ...
- Matrix Power Series POJ - 3233 矩阵幂次之和。
矩阵幂次之和. 自己想着想着就想到了一个解法,但是还没提交,因为POJ崩了,做了一个FIB的前n项和,也是用了这个方法,AC了,相信是可以得. 提交了,是AC的 http://poj.org/prob ...
- Sqoop Export HDFS
Sqoop Export应用场景——直接导出 直接导出 我们先复制一个表,然后将上一篇博文(Sqoop Import HDFS)导入的数据再导出到我们所复制的表里. sqoop export \ -- ...
- 《从0到1学习Flink》—— Data Sink 介绍
前言 再上一篇文章中 <从0到1学习Flink>-- Data Source 介绍 讲解了 Flink Data Source ,那么这里就来讲讲 Flink Data Sink 吧. 首 ...