【js】Leetcode每日一题-数组异或操作

【题目描述】

给你两个整数,n 和 start 。

数组 nums 定义为:nums[i] = start + 2*i(下标从 0 开始)且 n == nums.length 。

请返回 nums 中所有元素按位异或(XOR)后得到的结果。

示例1:

输入:n = 5, start = 0
输出:8
解释:数组 nums 为 [0, 2, 4, 6, 8],其中 (0 ^ 2 ^ 4 ^ 6 ^ 8) = 8 。
"^" 为按位异或 XOR 运算符。

示例2:

输入:n = 4, start = 3
输出:8
解释:数组 nums 为 [3, 5, 7, 9],其中 (3 ^ 5 ^ 7 ^ 9) = 8.

示例3:

输入:n = 1, start = 7
输出:7

示例4:

输入:n = 10, start = 5
输出:2

提示:

1 <= n <= 1000
0 <= start <= 1000
n == nums.length

【分析】

  • 朴素模拟就不谈了

  • 异或特性:

    定义\(sumXor(x)=0\bigoplus1\bigoplus2\bigoplus···\bigoplus x\),则

    以及化简式:

    对于此题,

  • AC代码

    var xorOperation = function(n, start) {
    const s = start >> 1, e = 1 & n & start;
    const ret = sumXor(s - 1) ^ sumXor(s + n - 1);
    return ret << 1 | e;
    }; const sumXor = function(x){
    if (x % 4 === 0) {
    return x;
    }
    if (x % 4 === 1) {
    return 1;
    }
    if (x % 4 === 2) {
    return x + 1;
    }
    return 0;
    }

最新文章

  1. 【转】Java出现No enclosing instance of type E is accessible. Must qualify the allocation with an enclosing
  2. 记录一次自己对nginx+fastcgi(fpm)+mysql压力测试结果
  3. Dynamic Time Warping 动态时间规整算法
  4. order by id asc得出的排序是什么原理
  5. cdoj 574 High-level ancients dfs序+线段树
  6. 在javascript中使用媒体查询media query
  7. A+B问题(java)
  8. java入门(1) 程序运行机制及运行过程
  9. 座IO理解力
  10. yate.conf
  11. bootstrap(响应式)加减输入框
  12. 重写轮子之 GaussionNB
  13. Ant Design Pro+Electron+electron-builder实现React应用脱离浏览器,桌面安装运行
  14. C# 可访问性不一致问题(修改成员的访问修饰符)。
  15. jmeter 获取执行脚本的路径
  16. centos memcached
  17. 一、图解Java中String不可变性
  18. sql server 数字字符串的排序
  19. mount nfs 经常出错信息总结(转)
  20. [转] Linux 3.10 ARM Device Tree 的初始化

热门文章

  1. Python爬虫学习三------requests+BeautifulSoup爬取简单网页
  2. 对话对话每日互动CEO方毅:数据智能应用的过去、现在和未来每日互动CEO方毅:数据智能应用的过去、现在和未来
  3. HashMap源码阅读(小白的java进阶)
  4. 从零开始编写一个BitTorrent下载器
  5. golang 三维向量相关操作
  6. 2018ICPC南京K. Kangaroo Puzzle
  7. JVM之对象创建、对象内存布局、对象访问定位
  8. 攻防世界 reverse debug
  9. springboot源码解析-管中窥豹系列之BeanDefine如何加载(十三)
  10. Mysql之索引选择及优化