| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 409 人关注过本帖, 1 人收藏
标题:看不明白,请高手解释下.
只看楼主 加入收藏
forclwy
Rank: 4
等 级:业余侠客
帖 子:167
专家分:255
注 册:2008-10-21
结帖率:100%
收藏(1)
 问题点数:0 回复次数:0 
看不明白,请高手解释下.
在一组数中如果有两个数出现了奇数次,求这两个数
int get_odd(int a[], int n)
{
int ans = 0;
for (int i = 0; i < n; ++i)
{
ans ^= a[i];
}
return ans;
}
void get_two_odd(int a[], int n)
{
// 找到两个数的异或结果,得到两个数的不相同的二进制位信息
int dif = get_odd(a, n);
// 随便取一位,这里找最低的二进制位
int temp = dif & (dif - 1) ^ dif;
int x(0), y(0);
for (int i = 0; i < n; ++i)
{
// 将数分成两组,分别异或得出结果
if (a[i] & temp)
x ^= a[i];
else
y ^= a[i];
}
cout << x << " " << y << endl;
}
搜索更多相关主题的帖子: 解释 
2009-10-17 20:19
快速回复:看不明白,请高手解释下.
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.020765 second(s), 7 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved