【js】Leetcode每日一题-数组异或操作
2024-09-01 02:30:42
【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;
}
最新文章
- 【转】Java出现No enclosing instance of type E is accessible. Must qualify the allocation with an enclosing
- 记录一次自己对nginx+fastcgi(fpm)+mysql压力测试结果
- Dynamic Time Warping 动态时间规整算法
- order by id asc得出的排序是什么原理
- cdoj 574 High-level ancients dfs序+线段树
- 在javascript中使用媒体查询media query
- A+B问题(java)
- java入门(1) 程序运行机制及运行过程
- 座IO理解力
- yate.conf
- bootstrap(响应式)加减输入框
- 重写轮子之 GaussionNB
- Ant Design Pro+Electron+electron-builder实现React应用脱离浏览器,桌面安装运行
- C# 可访问性不一致问题(修改成员的访问修饰符)。
- jmeter 获取执行脚本的路径
- centos memcached
- 一、图解Java中String不可变性
- sql server 数字字符串的排序
- mount nfs 经常出错信息总结(转)
- [转] Linux 3.10 ARM Device Tree 的初始化
热门文章
- Python爬虫学习三------requests+BeautifulSoup爬取简单网页
- 对话对话每日互动CEO方毅:数据智能应用的过去、现在和未来每日互动CEO方毅:数据智能应用的过去、现在和未来
- HashMap源码阅读(小白的java进阶)
- 从零开始编写一个BitTorrent下载器
- golang 三维向量相关操作
- 2018ICPC南京K. Kangaroo Puzzle
- JVM之对象创建、对象内存布局、对象访问定位
- 攻防世界 reverse debug
- springboot源码解析-管中窥豹系列之BeanDefine如何加载(十三)
- Mysql之索引选择及优化