每日一题——LeetCode1720.解码异或后的数组

方法一 异或运算的性质

encoded[i−1]=arr[i−1]⊕arr[i] 在等式两边同时异或arr[i−1] 由于:

  • 一个数异或它自己,结果总是0。

  • 0异或任何数,结果都是那个数本身。

所以等式可以转化为:

arr[i]=arr[i−1]⊕encoded[i−1]

由于 arr[0]=first已知,因此对 i从 1到 n−1依次计算 arr[i] 的值,即可解码得到原数组arr。

var decode = function(encoded, first) {
    const n = encoded.length + 1;
    const arr = new Array(n).fill(0);
    arr[0] = first;
    for (let i = 1; i < n; i++) {
        arr[i] = arr[i - 1] ^ encoded[i - 1];
    }
    return arr;
};

消耗时间和内存情况:

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2024-03-23 13:40:03       98 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-03-23 13:40:03       106 阅读
  3. 在Django里面运行非项目文件

    2024-03-23 13:40:03       87 阅读
  4. Python语言-面向对象

    2024-03-23 13:40:03       96 阅读

热门阅读

  1. LeetCode-热题100:131. 分割回文串

    2024-03-23 13:40:03       47 阅读
  2. web学习笔记(四十二)

    2024-03-23 13:40:03       41 阅读
  3. LeetCode

    2024-03-23 13:40:03       37 阅读
  4. 你用对const了吗?C++中const小结

    2024-03-23 13:40:03       39 阅读
  5. 鸿蒙开发 模拟器启动失败问题

    2024-03-23 13:40:03       86 阅读
  6. vue2【详解】mixins —— 抽离公共逻辑

    2024-03-23 13:40:03       36 阅读
  7. Selenium WebDriver使用EC来定义显式等待的条件

    2024-03-23 13:40:03       44 阅读
  8. Linux学习笔记16 - 系统命令

    2024-03-23 13:40:03       42 阅读
  9. Android 静默安装二(无障碍服务版)

    2024-03-23 13:40:03       45 阅读
  10. Windows C++ 监听注册表是否发生变化

    2024-03-23 13:40:03       44 阅读
  11. ChatGPT助力写作:论文写作新利器

    2024-03-23 13:40:03       52 阅读
  12. 001-Windows下PyTorch极简开发环境配置(上)

    2024-03-23 13:40:03       44 阅读