当前位置: 首页 > news >正文

LeetCode——2683. 相邻值的按位异或

通过万岁!!!

  • 题目:给你一个长度为n的数组derived,然后让你看下他能不能通过另外一个数组异或而来。规则是derived[i] = original[i] 异或 original[i+1],如果i位于最后i=n-1,则derived[i] = original[i] 异或 original[0]。然后数组只有0和1两个值。
  • 思路:首先是要知道异或什么意思。异或就是相同为0,不同为1。我们看下derived[i] = original[i] 异或 original[i+1]这个公式,其中derived[i]我们是知道的,这里先看i=0时,先假设derived[0]=0,则original[0]和original[1]相同,如果original[0]=0,那么original[1]=0。然后我们继续模拟derived[1],假设derived[1]=0,那么original[2]=0;如果derived[1]=1,那么original[2]只能等于1,因为他要与original[1]不能相同。所以我们可以看到,只要original[0]确定以后,后面的就都出来了。而且我们还能发现original[0]等于0或者等于1,都无所谓。上面的了解完了,我们就可以推导到original[n-1]了。注意了,我们找到了original[n-1],但是我们只满足了derived[n-2],因为derived[n-1]=original[n-1]异或original[0],而original[0]是我们假设的一个值。所以我们最后的结过只需要看original[n-1]异或original[0]是不是等于derived[n-1]就好了。
  • 技巧:数组、异或、位运算

java代码

class Solution {public boolean doesValidArrayExist(int[] derived) {// 异或,相同为0,不同为1int len = derived.length;int[] temp = new int[len];// temp[0] = 0for (int i = 1; i < len; i++) {if (derived[i - 1] == 0) {temp[i] = temp[i - 1];} else {// x & 1 = x % 2temp[i] = (temp[i - 1] + 1) & 1;}}return (temp[len - 1] ^ temp[0]) == derived[len - 1];}
}
  • 总结:关键就是我们需要发现,其实这个original有两个,一个是以0开头的,第二个是以1开头的。这样我们就可以随便假设original[0]了。
http://www.lryc.cn/news/610820.html

相关文章:

  • 下架的软件又复活了,低调使用!
  • HFSS许可审计与分析
  • 用 Python 批量处理 Excel:从重复值清洗到数据可视化
  • Go语言实战案例:使用context控制协程取消
  • 【工程化】tree-shaking 的作用以及配置
  • 小杰数据结构——题库——拂衣便欲沧海去,但许明月随吾身
  • EP02:【DL 第二弹】张量的索引、分片、合并以及维度调整
  • WWDC 25 极地冰原撸码危机:InlineArray 与 Span 的绝地反击
  • 基于MCP的智能客服系统:知识库与工单系统深度集成
  • C++ 网络编程入门:TCP 协议下的简易计算器项目
  • 面向对象编程基础:类的实例化与对象内存模型详解
  • 什么是mysql的垂直分表,理论依据是什么,如何使用?
  • 单链表应用实践
  • 【PCIE044】基于 JFM7VX690T 的全国产化 FPGA 开发套件
  • FPGA 基本设计思想--乒乓操作、串并转换、流水线
  • 数学建模算法-day[15]
  • 【MATLAB】(八)矩阵
  • 技术与情感交织的一生 (十一)
  • HTTP 与 HTTPS 的区别深度解析:从原理到实践
  • kettle插件-kettle http post plus插件,轻松解决https post接口无法调用文件流下载问题
  • 攻击实验(ARP欺骗、MAC攻击、报文洪水攻击、DNS欺骗)
  • 在 MCP 中实现 “askhuman” 式交互:原理、实践与开源方案
  • 灰色优选模型及算法MATLAB代码
  • 信息安全概述--实验总结
  • TCP如何实现可靠传输?实现细节?
  • 三极管基本放大电路静态及动态参数计算
  • 原生CSS vs LESS:样式表语言的进化之旅
  • 笔记学习杂记
  • (ZipList入门笔记二)为何ZipList可以实现内存压缩,可以详细介绍一下吗
  • 第19章 枚举器和迭代器 笔记