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

通过万岁!!!

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

java代码

java 复制代码
class Solution {
    public boolean doesValidArrayExist(int[] derived) {
        // 异或,相同为0,不同为1
        int len = derived.length;
        int[] temp = new int[len];
        // temp[0] = 0
        for (int i = 1; i < len; i++) {
            if (derived[i - 1] == 0) {
                temp[i] = temp[i - 1];
            } else {
                // x & 1 = x % 2
                temp[i] = (temp[i - 1] + 1) & 1;
            }
        }
        return (temp[len - 1] ^ temp[0]) == derived[len - 1];
    }
}
  • 总结:关键就是我们需要发现,其实这个original有两个,一个是以0开头的,第二个是以1开头的。这样我们就可以随便假设original0了。
相关推荐
可编程芯片开发14 分钟前
基于VSG虚拟同步发电机控制的三相并网逆变器带多组可变负载Simulink建模与仿真
算法
AI服务老曹18 分钟前
国产NPU视觉算法参数配置说明
算法·性能优化·边缘计算
彦为君27 分钟前
Redis最新版本特性
java·数据库·redis·算法·bootstrap
格子软件1 小时前
2026年GEO优化系统源码解构:核心状态机与高并发流控深度剖析
java·vue.js·spring boot·vue·geo
weixin199701080161 小时前
[特殊字符]《京东订单API(jd.order.detail.get)对接ERP:企业认证+OAuth授权避坑指南》(附Python源码)
java·数据库·python
触底反弹1 小时前
🔥 字符串算法面试三连击:反转、回文、回文变种,搞懂这三题稳了!
前端·javascript·算法
pW3g3lLuu1 小时前
在 VS Code 里直接改 JAR,我复刻了JarEditor
java·pycharm·jar
aaaameliaaa1 小时前
计算斐波那契数(递归、迭代)(1,1,2,3,5.....)
c语言·开发语言·笔记·算法·排序算法
Jerry2 小时前
LeetCode 977. 有序数组的平方
算法
Tim_102 小时前
【C++】009、extern关键字
java·开发语言