由买买提看人间百态

boards

本页内容为未名空间相应帖子的节选和存档,一周内的贴子最多显示50字,超过一周显示500字 访问原贴
JobHunting版 - 怎么判断一个数的二进制是不是回文数
相关主题
leetcode 一道题 valid palindrome[InterviewStreet] XOR key (50 Points),请pass的大牛给点思路
如何判断一个数是不是回文?问一道题
求教一个, Leetcode 题.求解面试题
请问大牛们Leetcode Palindrome Number 这道题(思路很简单,就是程序写不对)问一个关于xor的题
FB Phone Interview Failed by a simple question今早google电面报告
回文数的问题问一道brainteaser
palindrome partioning II一道位运算题
请教一道面试题两个Amazon面试题
相关话题的讨论汇总
话题: num话题: int话题: return话题: char话题: false
进入JobHunting版参与讨论
1 (共1页)
s******d
发帖数: 61
1
可以像这样通过以为来做吗?还是%10比较好,还有其他什么更好的方法吗?
public static boolean judgepalidrom(int num){
char[] ch=new char[Integer.size];
for(int i=0;i char[Integer.size-i-1]=(char)((num>>i)&1+'0');
}
String str=new String(ch);
for(int j=0;j if(str[j]!=str[str.length()-j-1])
return false;
}
return true;
}
i*****r
发帖数: 265
2
You can revert a binary number in logn time (n being the number of bits of
your integer, like 32-bit integer). Then you can compare if the reverted one
is the same as origin.
s******d
发帖数: 61
3
How to revert a binary number in logn time?
Thanks!!!
d*******d
发帖数: 2050
4
coask

【在 s******d 的大作中提到】
: How to revert a binary number in logn time?
: Thanks!!!

s**x
发帖数: 405
5
bool judge(int num){
if (num < 0) return false;
int x, y;
for (x = num, y = 0; x; x >>= 1)
y = (y << 1) | (x & 1);
return (y == num);
}
w*******s
发帖数: 96
6
check num = 00100100(binary) in your case:
you will only get y = 001001.
It looks ugly, but should work.
bool judge(int num){
if (num < 0) return false;
int i, x, y;
int bitsize = sizeof(num)*8;
for (i = 0, x = num, y = 0; i< bitsize ; x >>= 1,i++)
y = (y << 1) | (x & 1);
return (y == num);
}
i**********e
发帖数: 1145
7
Hint: use XOR.
g**********y
发帖数: 14569
8
他这个不用形成那个反转数,只用判断是不是回文就行,简单code (对32-bit):
boolean isPalindrome(int n) {
for (int i=0; i<16; i++) {
if ((n>>i) != (n>>(31-i))) return false;
}
return true;
}

【在 i**********e 的大作中提到】
: Hint: use XOR.
s**x
发帖数: 405
9
waveletus, it seems our interpretation of the problem is different
my view is that binary encoding of integers always start with '1' bits.
for example 00100100 should just be 100100.
100100 should be false.
10101 should be true.

【在 w*******s 的大作中提到】
: check num = 00100100(binary) in your case:
: you will only get y = 001001.
: It looks ugly, but should work.
: bool judge(int num){
: if (num < 0) return false;
: int i, x, y;
: int bitsize = sizeof(num)*8;
: for (i = 0, x = num, y = 0; i< bitsize ; x >>= 1,i++)
: y = (y << 1) | (x & 1);
: return (y == num);

1 (共1页)
进入JobHunting版参与讨论
相关主题
两个Amazon面试题FB Phone Interview Failed by a simple question
一道题目回文数的问题
Pow有没有比log(n)更好点的解法?palindrome partioning II
Citibank 第二轮请教一道面试题
leetcode 一道题 valid palindrome[InterviewStreet] XOR key (50 Points),请pass的大牛给点思路
如何判断一个数是不是回文?问一道题
求教一个, Leetcode 题.求解面试题
请问大牛们Leetcode Palindrome Number 这道题(思路很简单,就是程序写不对)问一个关于xor的题
相关话题的讨论汇总
话题: num话题: int话题: return话题: char话题: false