接上文leetcode - 位运算题目汇总(上),继续来切leetcode中Bit Manipulation下的题目。

Bitwise AND of Numbers Range


给出一个范围,[m, n](0 <= m <= n <= 2147483647),返回这些数字的与运算结果。

直接逐个做与运算,TLE,我们得发现高效解法。

我们把[0, 15]用二进制码表示出来:

0 0 0 0
0 0 0 1
0 0 1 0
0 0 1 1
0 1 0 0
0 1 0 1
0 1 1 0
0 1 1 1
1 0 0 0
1 0 0 1
1 0 1 0
1 0 1 1
1 1 0 0
1 1 0 1
1 1 1 0
1 1 1 1

仔细看,几个连续的二进制码肯定会有相同的前缀(前缀长度可能为0),比如以下的二进制码相同的前缀就是1 0:

1 0 0 0
1 0 0 1
1 0 1 0
1 0 1 1

除了相同的前缀外,将之后的各位置为0即为所求:1 0 0 0,也就是8。如何求解这个相同前缀?只需要m和n同时右移,直到两数相等为止:

/**
 * @param {number} m
 * @param {number} n
 * @return {number}
 */
var rangeBitwiseAnd = function(m, n) {
  if (m === n)
    return m;

  var tmp = rangeBitwiseAnd(m >> 1, n >> 1);
  return tmp << 1;
};

还有一种更巧妙的方法,将n的最右边的 1 bit 置为0,直到值不大于m即可:

/**
 * @param {number} m
 * @param {number} n
 * @return {number}
 */
var rangeBitwiseAnd = function(m, n) {
  while (m < n)
    n = n & (n - 1);
  return n;
};

Repeated DNA Sequences


给你一串字符串表示DNA,输出重复的子串。

Given s = "AAAAACCCCCAAAAACCCCCCAAAAAGGGTTT",

Return:
["AAAAACCCCC", "CCCCCAAAAA"].

直接用JavaScript的对象哈希字符串,提交,MLE:

var findRepeatedDnaSequences = function(s) {
  var hash = {}
    , ans = 0;

  for (var i = 0, len = s.length; i < len; i++) {
    var str = s.substr(i, 10);
    if (str.length < 10) break;
    if (!hash[str])
      hash[str] = 1;
    else if (hash[str] === 1)
      hash[str]++, ans++;
  }

  return ans;
};

这题的关键是如何哈希,幸运的是JavaScript虽然没有C++那样强大的stl,但是也有Set,我们用set进行哈希,AC:

var findRepeatedDnaSequences = function(s) {
  var hash = new Set()
    , hash_ans = new Set()
    , ans = [];

  for (var i = 0, len = s.length; i < len; i++) {
    var str = s.substr(i, 10);
    if (str.length < 10) break;
    if (!hash.has(str))
      hash.add(str);
    else {
      if (!hash_ans.has(str)) {
        hash_ans.add(str);
        ans.push(str);
      }
    }
  }

  return ans;
};

但是好像没有说到位运算啊!我们思考下如何用数字哈希代替字符串哈希以减少内存消耗。

如果只有两种字符,我们便可以用0和1分别代替字符,组成一个二进制码,然后用一个整数代替这个二进制码完成哈希。但是不幸的是,现在有四个字符,如何?4进制?4进制的确是个好办法,但是操作起来不方便,我们可以用两位二进制码代替一位四进制码,比如我们分别用0 1 2 3表示A C G T,用两位的二进制码00 01 10 11代替0 1 2 3

var findRepeatedDnaSequences = function(s) {
  var map = []
    , hash = new Array(0xfffff)
    , ans = [];

  map['A'] = 0, map['C'] = 1, map['G'] = 2, map['T'] = 3;

  var tmp = 0;
  for (var i = 0, len = s.length; i < len; i++) {
    tmp = tmp << 2 | map[s[i]];
    if (i < 9) continue;
    if (i > 9) tmp = tmp & 0xfffff;

    if (!hash[tmp])
      hash[tmp] = 1;
    else if (hash[tmp] === 1)
      hash[tmp]++, ans.push(s.substring(i - 9, i + 1));
  }

  return ans;
};

不幸的是,又是MLE...这里不得不嗔怪下JavaScript对象的“吝啬”,稍微内存大搞大点,就MLE了,其实也就开了1048575大的数组。还好我们有set..

var findRepeatedDnaSequences = function(s) {
  var map = []
    , hash = new Set()
    , hash_ans = new Set()
    , ans = [];

  map['A'] = 0, map['C'] = 1, map['G'] = 2, map['T'] = 3;

  var tmp = 0;
  for (var i = 0, len = s.length; i < len; i++) {
    tmp = tmp << 2 | map[s[i]];
    if (i < 9) continue;
    if (i > 9) tmp = tmp & 0xfffff;

    if (!hash.has(tmp))
      hash.add(tmp);
    else {
      if (!hash_ans.has(tmp)) {
        hash_ans.add(tmp);
        ans.push(s.substring(i - 9, i + 1));
      }
    }
  }

  return ans;
};

144ms beats 100% JavaScript submissions

其他


其他题目我在别的文章中都有所涉及:

  1. Single Number【位运算经典应用】 寻找那个唯一的数
  2. Single Number II(同上)
  3. Single Number III(同上)
  4. Number of 1 BitsJavaScript 位运算总结&拾遗
  5. Reverse Bits【位运算经典应用】 求二进制逆序

leetcode - 位运算题目汇总(下)的更多相关文章

  1. leetcode - 位运算题目汇总(上)

    最近在看位运算的知识,十分感叹于位运算的博大精深,正好leetcode有 Bit Manipulation 的专题,正好拿来练练手. Subsets 给出一个由不同的数字组成的数组,枚举它的子数组(子 ...

  2. leetcode top 100 题目汇总

    首先表达我对leetcode网站的感谢,与高校的OJ系统相比,leetcode上面的题目更贴近工作的需要,而且支持的语言广泛.对于一些比较困难的题目,可以从讨论区中学习别人的思路,这一点很方便. 经过 ...

  3. All LeetCode Questions List 题目汇总

    All LeetCode Questions List(Part of Answers, still updating) 题目汇总及部分答案(持续更新中) Leetcode problems clas ...

  4. 78 leetCode 位运算解法

    按照自己的理解题目,数组内所有的组合:假如[1,2,3,4]看成1111到0000里面的排列组合,取位运算. vector<vector > subsets(vector&nums ...

  5. leetcode.位运算.136只出现一次的元素-Java

    1. 具体题目 给定一个非空整数数组,除了某个元素只出现一次以外,其余每个元素均出现两次.找出那个只出现了一次的元素. 说明:你的算法应该具有线性时间复杂度. 你可以不使用额外空间来实现吗? 示例 1 ...

  6. BitMap - leetcode [位运算]

    136. Single Number 因为A XOR A = 0,且XOR运算是可交换的,于是,对于实例{2,1,4,5,2,4,1}就会有这样的结果: (2^1^4^5^2^4^1) => ( ...

  7. leetcode 位运算异或

    1. 只出现一次的数字(136) 异或的性质总结: 相异为1,相同为0: a ^ a = 0; 0 ^ a = a; 如果 a ^ b = c 成立,那么a ^ c = b 与 b ^ c = a 均 ...

  8. JavaScript 位运算总结&拾遗

    最近补充了一些位运算的知识,深感位运算的博大精深,此文作为这个系列的总结篇,在此回顾下所学的位运算知识和应用,同时也补充下前文中没有提到的一些位运算知识. 把一个数变为大于等于该数的最小的2的幂 一个 ...

  9. 位运算总结&拾遗

    JavaScript 位运算总结&拾遗 最近补充了一些位运算的知识,深感位运算的博大精深,此文作为这个系列的总结篇,在此回顾下所学的位运算知识和应用,同时也补充下前文中没有提到的一些位运算知识 ...

随机推荐

  1. MySQL 调优基础(二) Linux内存管理

    进程的运行,必须使用内存.下图是Linux中进程中的内存的分布图: 其中最重要的 heap segment 和 stack segment.其它内存段基本是大小固定的.注意stack是向低地址增长的, ...

  2. 在DigitalOcean云主机上搭建SVN服务器

    最近买了个DigitalOcean主机,顺便搭建个PPTP SVN服务器. 下面是搭建方法: https://www.digitalocean.com/community/tutorials/how- ...

  3. js实现打开网页自动弹出添加QQ好友邀请窗口

    我们有时进一些网面或专题页面会自动弹出一个加为好友的对话框了,在研究了很久之后发现可以直接使用js来实现,下面我们一起来看js实现打开网页自动弹出添加QQ好友邀请窗口的方法. 第一步.JS脚本 这个是 ...

  4. TeX Live安装配置等默认目录

    TeX Live默认目录情况:   TEXDIR (the main TeX directory):     !! default location: /usr/local/texlive/2015  ...

  5. Sql server2012连接Sql server 2008时出现的问题:已成功与服务器建立连接,但在登陆过程中发生错误。(provider:SSL Provider,error:0-接收到的消息异常,或格式不正确。)

    以前连接是正常的,就这两天连不上了.(没有耐心的直接看末尾解决办法) 错误消息如下: 1.尝试读取或写入受保护的内存.这通常指示其他内存已损坏.(System.Data) 2.已成功与服务器建立连接, ...

  6. 【温故而知新-Javascript】使用canvas元素(第一部分)

    1. 开始使用 canvas 元素 canvas 元素非常简单,这是指它所有的功能都体现在一个JavaScript对象上,因此该元素本身只有两个属性:width 和 height. canvas 元素 ...

  7. file_get_contents模仿浏览器头(user_agent)获取数据

    本篇文章是对file_get_contents模仿浏览器头(user_agent)获取数据进行了详细的分析介绍,需要的朋友参考下     什么是user agentUser Agent中文名为用户代理 ...

  8. AC日记——与7无关的数 openjudge 1.5 39

    39:与7无关的数 总时间限制:  1000ms 内存限制:  65536kB 描述 一个正整数,如果它能被7整除,或者它的十进制表示法中某一位上的数字为7,则称其为与7相关的数.现求所有小于等于n( ...

  9. AC日记——ISBN号码 openjudge 1.7 29

    29:ISBN号码 总时间限制:  1000ms 内存限制:  65536kB 描述 每一本正式出版的图书都有一个ISBN号码与之对应,ISBN码包括9位数字.1位识别码和3位分隔符,其规定格式如“x ...

  10. 当手机被PS掉,人们看到的是手中的灵魂

    Eric Pickersgill是一名摄影师,最近喜欢拍摄并记录人们使用智能手机的情景,不过不同的是,在最终作品中会将手机从人们手中PS掉,一刹那会进入一个奇怪的世界.黑白照片也极具冲击力. 每个人神 ...