http://www.acmerblog.com/leetcode-single-number-ii-5394.html acm之家的讲解总是那么到位 public class Solution {
public int singleNumber(int[] A) {
int ans=0; //0^X=X x^X=x
for(int i=0;i<A.length;i++)
{
ans=ans^A[i];
}
return ans;
}
}
sing number (2)
高端方法太难了,不想看了,位运算点到为止吧,
public class Solution {
public int singleNumber(int[] A) {
int count[]=new int[32]; //统计每个位1的个数,Int 32,因为都是成三出现,所以最终每个位一的个数为count[j]%3.其实他的
结果只能为 1或0,2是不可能的。
int result=0;
for(int j=0;j<32;j++)
{
for(int i=0;i<A.length;i++)
{ int n=A[i];
if(((n>>j)&1)==1){ //这句话纠结死我了,原来==的优先级大于&,所以别忘了加括号啊
count[j]=(count[j]+1)%3;
}
} result=result|(count[j]<<j); } return result; } }