设为首页 加入收藏

TOP

LeetCode:signal_number题解
2015-07-20 17:33:35 来源: 作者: 【 】 浏览:3
Tags:LeetCode:signal_number 题解

一、题目:这道题是说给你一个数组,其中的数有两个是相同的也可以说是成对的,只有一个例外,所以题目说找出光棍数(signal number)

二、分析:这道题,它说不能再使用额外的内存,而且得是线性O(n)的复杂度其实这个是有技巧的,位运算( ^ )

例如:

Array[5]={2,4,3,4,2}

010

100

011

100

^ 010

-----------

= 011

故可得解

class Solution {
public:
    int singleNumber(int A[], int n) {
        // Note: The Solution object is instantiated only once and is reused by each test case.
        int flag = 0;
        while(n){
            flag ^= A[n];
        }
        return flag;
    }
};


】【打印繁体】【投稿】【收藏】 【推荐】【举报】【评论】 【关闭】 【返回顶部
分享到: 
上一篇MVC [Control与View交互]2 下一篇Codeforces 4B-Before an Exam(..

评论

帐  号: 密码: (新用户注册)
验 证 码:
表  情:
内  容:

·每日一道面试题-多线 (2025-12-26 06:20:17)
·java项目中哪些地方 (2025-12-26 06:20:14)
·Java真的是要没落了 (2025-12-26 06:20:12)
·C++ Lambda表达式保 (2025-12-26 05:49:45)
·C++ Lambda表达式的 (2025-12-26 05:49:42)