求唯一一个只出现一次的数字

输入一串数字,其中只有一个数字只出现一次,其他数字均出现两次,要求找出这个只出现一次的数字。

1、第一种方式依次遍历每一个数字,然后再遍历这个数字之后的数字如果没有重复则就是它,否则就继续,这种方法算法复杂度为 O(n²)

2、第二种方式可以借用 map ,牺牲空间换取时间,算法复杂度 O(n) 。

3、第三种借用 0 ^ i = i , i ^ i = 0 的特性,效率最高,不用牺牲额外空间。

def findSingleNumber():
    row_str = raw_input(r"输入:")
    nums = [int(i) for i in row_str.split(",")]

    # 第二种方式
    # m = {}
    # for i in nums:
    #     if i in m.keys():
    #         m.pop(i)
    #         continue
    #     m[i] = True
    #
    # print m.keys()[0]

    # 第三种方式
    temp = 0
    for i in nums:
        temp = temp ^ i
    print temp

 

转载于:https://my.oschina.net/zhxx/blog/3034804

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值