博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
leetcode - 位运算题目汇总(下)
阅读量:6291 次
发布时间:2019-06-22

本文共 2999 字,大约阅读时间需要 9 分钟。

接上文,继续来切leetcode中下的题目。


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

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

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

0 0 0 00 0 0 10 0 1 00 0 1 10 1 0 00 1 0 10 1 1 00 1 1 11 0 0 01 0 0 11 0 1 01 0 1 11 1 0 01 1 0 11 1 1 01 1 1 1

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

1 0 0 01 0 0 11 0 1 01 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;};


给你一串字符串表示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进行哈希,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. ()
  2. (同上)
  3. (同上)
  4. ()
  5. ()

转载地址:http://pdcta.baihongyu.com/

你可能感兴趣的文章
这是我的第1个C#程序(向控制台输出一句话)
查看>>
html
查看>>
Xqk.Data数据框架开发指南:丰富的、灵活的查询方法(第三部分:SqlField)
查看>>
工作第十五周:上线前的惊悚
查看>>
Java获取EXE文件图标的方法
查看>>
深入解析Django Admin模块
查看>>
SQL Server死锁详解
查看>>
电影剧本写作基础
查看>>
7.11 计算机基础
查看>>
虚拟机 liunx系统以 root 身份登录权限
查看>>
《当程序员的那些狗日日子》(五十一)太不给力的年终奖
查看>>
LeetCode(203): Remove Linked List Elements
查看>>
Join和Relate作用和区别
查看>>
mysql中的意向锁IS,IX
查看>>
CSS学习笔记02float
查看>>
python库的学习系列之 15. Generic Operating System Services
查看>>
使用excel进行数据挖掘(5)---- 应用场景分析
查看>>
【CSS】隐藏多行文本框Textarea在IE中的垂直滚动栏
查看>>
2017-2018-1 《信息安全系统设计基础》实验一报告
查看>>
2017-2018-1 20155303 《信息安全系统设计基础》第五周学习总结
查看>>