如何检查整数的二进制表示形式是否是回文?
如何检查整数的二进制表示形式是否是回文?
How to check if the binary representation of an integer is a palindrome?
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
如何检查整数的二进制表示形式是否是回文?
How to check if the binary representation of an integer is a palindrome?
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
接受
或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
发布评论
评论(18)
这里有很多不错的解决方案。 让我添加一个在我看来不是最有效但非常可读的:
Plenty of nice solutions here. Let me add one that is not the most efficient, but very readable, in my opinion:
以下内容应该适用于任何无符号类型。 (有符号类型的位操作往往充满问题。)
The following should be adaptable to any unsigned type. (Bit operations on signed types tend to be fraught with problems.)
我总是有一个与字符串一起使用的回文函数,如果是,则返回 true,否则返回 false,例如在 Java 中。 我唯一需要做的就是:
I always have a palindrome function that works with Strings, that returns true if it is, false otherwise, e.g. in Java. The only thing I need to do is something like:
通用版本:
A generic version:
我认为最好的方法是从末尾开始并向内工作,即比较第一位和最后一位、第二位和倒数第二位等,这将具有 O(N/2) 其中 N是 int 的大小。 如果在任何时候你的对不相同,那么它就不是回文。
I think the best approach is to start at the ends and work your way inward, i.e. compare the first bit and the last bit, the second bit and the second to last bit, etc, which will have O(N/2) where N is the size of the int. If at any point your pairs aren't the same, it isn't a palindrome.
有时报告失败也很好;
这里有很多关于明显的方法的很好的答案,通过以某种形式或其他位模式进行分析。 不过,我想知道是否有任何数学解决方案? 我们可以利用回文数的属性吗?
所以我稍微做了一些数学运算,但答案从一开始就应该是显而易见的。 证明所有二进制回文数必须是奇数或零是很简单的。 这就是我所能做到的。
一些研究表明,十进制回文数没有这种方法,因此它要么是一个非常困难的问题,要么无法通过正式系统解决。 证明后者可能会很有趣......
Sometimes it's good to report a failure too;
There are lots of great answers here about the obvious way to do it, by analyzing in some form or other the bit pattern. I got to wondering, though, if there were any mathematical solutions? Are there properties of palendromic numbers that we might take advantage of?
So I played with the math a little bit, but the answer should really have been obvious from the start. It's trivial to prove that all binary palindromic numbers must be either odd or zero. That's about as far as I was able to get with it.
A little research showed no such approach for decimal palindromes, so it's either a very difficult problem or not solvable via a formal system. It might be interesting to prove the latter...
我知道这个问题已经在两年前发布了,但是我有一个更好的解决方案,它不依赖于字长等,
I know that this question has been posted 2 years ago, but I have a better solution which doesn't depend on the word size and all,
在 JAVA 中,如果您了解基本的二进制算术,有一个简单的方法,代码如下:
In JAVA there is an easy way if you understand basic binary airthmetic, here is the code:
下面的解决方案适用于 python:
def CheckBinPal(b):
b=str(bin(b))
如果 b[2:]==b[:1:-1]:
返回真
别的:
返回 False
其中 b 是整数
The solution below works in python:
def CheckBinPal(b):
b=str(bin(b))
if b[2:]==b[:1:-1]:
return True
else:
return False
where b is the integer
如果您使用 Clang,则可以使用一些
__builtin
。需要注意的一件事是
__builtin_clz(0)
未定义,因此您需要检查是否为零。 如果您使用 Clang(下一代 Mac)在 ARM 上进行编译,那么这将利用反向和 clz 的汇编指令 (编译器资源管理器)。x86 有 clz 的指令(有点),但没有反转。 尽管如此,Clang 将发出尽可能最快的代码来在目标架构上进行逆向操作。
If you're using Clang, you can make use of some
__builtin
s.One thing to note is that
__builtin_clz(0)
is undefined so you'll need to check for zero. If you're compiling on ARM using Clang (next generation mac), then this makes use of the assembly instructions for reverse and clz (compiler explorer).x86 has instructions for clz (sort of) but not reversing. Still, Clang will emit the fastest code possible for reversing on the target architecture.
JavaScript 解决方案
Javascript Solution
希望正确:
Hopefully correct:
由于您尚未指定执行此操作的语言,因此这里有一些 C 代码(不是最有效的实现,但它应该说明这一点):
编辑 已修复您的 10001 事物。
Since you haven't specified a language in which to do it, here's some C code (not the most efficient implementation, but it should illustrate the point):
EDIT fixed for your 10001 thing.
创建一个包含一个字符及其位反转字符的 256 折线图表。
给定一个 4 字节整数,
取出第一个字符,在图表上查看,将结果与整数的最后一个字符进行比较。
如果它们不同,则不是回文,如果相同,则用中间字符重复。
如果它们不同,则不是回文,否则就是。
Create a 256 lines chart containing a char and it's bit reversed char.
given a 4 byte integer,
take the first char, look it on the chart, compare the answer to the last char of the integer.
if they differ it is not palindrome, if the are the same repeat with the middle chars.
if they differ it is not palindrome else it is.