求解按位代数中的未知数

发布于 2024-11-24 02:21:12 字数 237 浏览 6 评论 0原文

假设我有 3 个字节,XY 和 Z。X

XOR Y 结果为 Z。

我知道 X 和 Z 是什么,但我不知道 Y 是什么,所以我正在编写一个快速脚本来解决这个问题。

不过,我什至不知道如何开始。我手工做了几个,这只是逐一比较的问题,但我怎样才能在 python 中做到这一点呢?我求解 Y 的过程似乎不够清晰。

因为我只需要实际使用这样的东西,所以要么编写它,要么只使用为我做这件事的东西就足够了。

Suppose I have 3 bytes, X Y and Z.

X XOR Y results in Z.

I know what X and Z are, but I don't know what Y is, so I'm writing a quick script to figure this out.

Though, I don't know how I would even begin. I did a couple of them by hand and it was simply a matter of comparing each bit one by one, but how can I do this in python? My procedure for solving for Y doesn't seem clear enough.

Since I just need to actually use something like this, it would be enough to either write it or just use something that does this for me.

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(1

谈场末日恋爱 2024-12-01 02:21:12

如果x ^ y == z,则x ^ z == y。您可以在 Python 中验证这一点

>>> X = range(256)  # all byte values
>>> Y = range(256)
>>> all(x ^ z == y for x in X for y in Y for z in [x^y])

If x ^ y == z, then x ^ z == y. You can verify this in Python with

>>> X = range(256)  # all byte values
>>> Y = range(256)
>>> all(x ^ z == y for x in X for y in Y for z in [x^y])
~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文