题目:一个整型数组里除了两个数字之外,其他的数字都出现了两次。请写程序找出这两个只出现一次的数字

通过这道题感觉位运算很强大~这道题利用异或的几个性质:任何数与其本身异或值都为0,异或运算满足交换律。因此将一组数依次异或,若里面只有一个只出现一次的数,其他的数都出现两次,则最后的结果必然是那个只出现一次的数。要找到两个数字就可以先通过异或整个数组,将得到的结果分组。然后依次安组异或就可以得到所求的值~

代码如下:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
#include<iostream>
using namespace std;
int findFirstOne(int value);
bool testBit(int value,int pos);
int findNums(int date[],int length,int &num1,int &num2){
    if(length<2){return -1;}
    int ansXor=0;
    for(int i=0;i<length;i++){
        ansXor^=date[i];               //异或
    }
    int pos=findFirstOne(ansXor);
    num1=num2=0;
    for(int i=0;i<length;i++){
        if(testBit(date[i],pos))
            num1^=date[i];
        else
            num2^=date[i];
    }
    return 0;
}
int findFirstOne(int value){     //取二进制中首个为1的位置
    int pos=1;
    while((value&1)!=1){
        value=value>>1;
        pos++;
    }
    return pos;
}
bool testBit(int value,int pos){  //测试某位置是否为1
    return ((value>>pos)&1);
}
int main(void){
    int date[10]={1,2,3,4,5,6,4,3,2,1};
    int ans1,ans2;
    if(findNums(date,10,ans1,ans2)==0)
        cout<<ans1<<" "<<ans2<<endl;
    else
        cout<<"error"<<endl;
    return 0;
}

找出数组中两个只出现一次的数字相关推荐

  1. 微策略2011校园招聘笔试题(找出数组中两个只出现一次的数字)

    1.8*8的棋盘上面放着64个不同价值的礼物,每个小的棋盘上面放置一个礼物(礼物的价值大于0),一个人初始位置在棋盘的左上角,每次他只能向下或向右移动一步,并拿走对应棋盘上的礼物,结束位置在棋盘的右下 ...

  2. 【算法14】找出数组中两个只出现一次的数字

    [题 目]一个整型数组中除了两个数字外,其他的数字都出现两次.请找出这两个只在数组中出现一次的数字.要求时间复杂度O(n),空间复杂度O(1). [思 路]首先我们考虑一个稍微简单点的情况:如果这个数 ...

  3. 找出数组中两个只出现了一次的数

    原题:给一组数,只有两个数只出现了一次,其他所有数都是成对出现的.怎么找出这两个数. 编写函数实现. 对于一组数中只有一个数只出现一次,其他所有数都是成对出现的,我们采用了对全部数组元素进行异或,经过 ...

  4. 找出数组中第k大和第m大的数字之和

    找出数组中第k大和第m大的数字之和 说明:定义一个函数,接受三个参数getMaxNumber(array,k,m){},找出第k大和第m大的数字之和.重复的数组也需要计算 比如:[1,3,4,5,4, ...

  5. 算法题:找出整数数组中两个只出现一次的数字

    问题:一个整数数组里除了两个数字之外,其他的数字都出现了两次.请写程序找出这两个只出现一次的数字.要求时间复杂度为O(n),空间复杂度为O(1). 分析:这是一个很新颖的关于位运算的题目. 首先考虑这 ...

  6. 找出数组中两数之和为指定值的所有整数对

    一,问题描述 给定一个整型数组(数组中的元素可重复),以及一个指定的值.打印出数组中两数之和为指定值的 所有整数对 二,算法分析 一共有两种方法来求解.方法一借助排序,方法二采用HashSet 方法一 ...

  7. c语言实现在数组中找一个数字显示,C语言找出数组中的特定元素的算法解析

    问题描述:一个int数组,里面数据无任何限制,要求求出所有这样的数a[i],其左边的数都小于等于它,右边的数都大于等于它.能否只用一个额外数组和少量其它空间实现. 思路:如果能用两个辅助数组,那么相对 ...

  8. 找出数组中只出现了一次的数字(Java)

    找出数组中只出现了一次的数字 题目 题目分析 方法1 方法2 方法3 代码实现 主方法 方法1 第一种:使用计数器的 第二种:不使用计数器 方法2 方法3 总结 题目 给定一个非空整数数组,除了某个元 ...

  9. 找出数组中出现次数超过一半的数

    算法--找出数组中出现次数超过一半的数      每当我看到经典的算法题,就怀念高中,感觉很多算法题就是高中的题目,谁叫哥只读了个专科,高数基本相当没学.      有空要看看高数啊,想当年数学那是相 ...

最新文章

  1. This和Super关键字的对比
  2. 快讯 | 第二届数据标准化及治理大会成功举办,清华力量助推中国数据标准化建设
  3. 关于ccflow的编译错误
  4. 赖美云的认证照_真人秀及综艺类双榜单TOP10嘉宾热度认证 赖美云双面魅力引热议...
  5. 信息抽取新SOTA!首个结构化生成式信息抽取预训练模型,一统信息抽取四大任务...
  6. RabbitMQ(一):Hello World程序
  7. 如何使用python批量压缩图片_python利用Guetzli批量压缩图片
  8. 浅谈 *.axf,*.bin,*.hex 文件
  9. 美元符号在什么计算机语言,美元符号是什么?怎么打?
  10. 演唱会舞台怎么设计?不妨看看这位建筑大师怎么玩!
  11. 计算机主题绘画能画什么,电脑绘画活动方案
  12. 自制BSL编程MSP430单片机
  13. 深入理解 MySQL 主键和唯一(unique)索引
  14. matlab实现单(双)极性,Matlab实现单(双)极性(不)归零码
  15. Linux下如何彻底删除用户
  16. 遇到长GC停顿、CPU满载、内存泄露、JVM崩溃等高频问题,看这里!
  17. PMP证书怎么续证?PDU要怎么获得?超过有效期证书就作废了吗?
  18. EFM32G232F64时钟树
  19. 携手捷普 :让流程立于云端,臻于至善
  20. 小i机器人与腾讯、商汤等发起成立上海人工智能发展联盟

热门文章

  1. 【错误记录】Windows 系统 bat 脚本报错 ( Java 生成 bat 脚本乱码处理 | 输出 GB2312 字符串 | Windows 中的换行时 \r\n )
  2. 【Flutter】FutureBuilder 异步编程 ( FutureBuilder 构造方法 | AsyncSnapshot 异步计算 )
  3. 【设计模式】组合模式 ( 简介 | 适用场景 | 优缺点 | 代码示例 )
  4. 【Android 组件化】路由组件 ( 路由组件结构 )
  5. 列表,集合,元组,字典
  6. 多态Poly中的向上/下转型 Upcast/Downcast
  7. Java编程基础篇第二章
  8. 关于使用data()获取自定义属性出现undefined的说明
  9. java stringBuilder的用法
  10. javaweb学习总结(八)——HttpServletResponse对象(二)