寻找数组中唯一只出现1次的数

一个数组中除开唯一一个元素只出现一次,其余的元素均出现三次。

位运算,看不明白,留着以后看吧。

 1 #include <stdio.h>
 2 #include <algorithm>
 3 using namespace std;
 4 #define maxn 1000
 5 int a[maxn],n;
 6
 7 int main()
 8 {
 9     while(scanf("%d",&n), n)
10     {
11         int one = 0, two = 0, three = 0;
12         for(int i=0; i<n; i++)
13         {
14             scanf("%d",&a[i]);
15             three = two & a[i];
16             two = two | one & a[i];
17             one = one | a[i];
18             two = two & ~three;
19             one = one & ~three;
20         }
21         printf("%d\n",one);
22     }
23     return 0;
24 }
时间: 2024-07-29 07:04:53

寻找数组中唯一只出现1次的数的相关文章

《剑指offer》第五十六题II:数组中唯一只出现一次的数字

// 面试题56(二):数组中唯一只出现一次的数字 // 题目:在一个数组中除了一个数字只出现一次之外,其他数字都出现了三次.请 // 找出那个吃出现一次的数字. #include <cstdio> #include <exception> int FindNumberAppearingOnce(int numbers[], int length) { if (numbers == nullptr || length <= 0) throw new std::exceptio

74. 数组中唯一只出现一次的数字

没按题目要求做啊 class Solution { public: int findNumberAppearingOnce(vector<int>& nums) { int n=nums.size()-1; unordered_map<int,int > hash; for(int i=0;i<=n;i++) { hash[nums[i]]++; } for(int i=0;i<=n;i++) { if(hash[nums[i]] == 1) return nu

找出其他数出现两次的数组中唯一一个出现一次的数

#include <stdio.h> #include <stdlib.h> #include <malloc.h> /* 有101个整数, 其中有50个数出现了两次, 1个数出现了一次, 找出出现了一次的那个数. */ /* 思路: 出现两次的数进行异或为0, 故将整个数组的数进行异或, 则得到此只出现一次的那个数 */ int isOdd(int num); int getOne(int *arr, int length); int main(){ int numb

算法题1 数组中唯一出现1次的数|唯一出现2次的数

题目描述:一个整型数组里除了1个数字之外,其他的数字都出现了两次,请写程序找出这个只出现一次的数字.要求时间复杂度是 O(n),空间复杂度是 O(1),例如输入数组{2, 4, 3, 3, 2, 5 },因为只有 4 这个数字只出现一次,其他数字都出现了两次,所以输出 4 思路分析:本题以及延伸题目,在剑指offer上有详细描述.利用异或的特性,x^y^x=y^x^x=y.对数组所有元素一次进行异或操作,最终得到的值就是那个只出现一次的数字 代码 1 int FindOnceNum(int ar

找出数组中唯一的重复元素

[问题] 1-1000放在含有1001个元素的数组中,只有唯一的一个元素值重复,其它均只出现一次. 每个数组元素只能访问一次,设计一个算法,将它找出来:不用辅助存储空间,能否设计一个算法实现? [代码] #include <stdio.h> #include <stdlib.h> #include <string.h> /*根据异或法的计算方式,每两个相异的数执行异或运算之后,结果为1: 每两个相同的数异或之后,结果为0,任何数与0异或,结果仍为自身. 所以数组a[N]

编程之美3:寻找数组中的最大值和最小值以及最大值和次大值

很开心,这是今天的第三篇文章啦!下午健身也感觉非常过瘾,托付宿舍妹子从日本代购的护肤品也到了.耳边漂浮着Hebe田馥甄的<魔鬼中的天使>文艺的声线,一切都好棒,O(∩_∩)O哈哈~.爱生活,爱音乐,爱运动,额,当然还有要爱学习啦!加油(^ω^) 额,扯远了.第三篇是关于寻找数组中的最大值和最小值.第一次看到这个题目的时候,楼主稍微鄙视了一下,因为觉得这个题目有什么好做的.但是楼主还是看了看<编程之美>上的写的,发现还是有必要记录一下,不一样的思考方式.很赞!大家和楼主一起哦,Are

[经典算法题]寻找数组中第K大的数的方法总结

[经典算法题]寻找数组中第K大的数的方法总结 责任编辑:admin 日期:2012-11-26 字体:[大 中 小] 打印复制链接我要评论 今天看算法分析是,看到一个这样的问题,就是在一堆数据中查找到第k个大的值. 名称是:设计一组N个数,确定其中第k个最大值,这是一个选择问题,当然,解决这个问题的方法很多,本人在网上搜索了一番,查找到以下的方式,决定很好,推荐给大家. 所谓"第(前)k大数问题"指的是在长度为n(n>=k)的乱序数组中S找出从大到小顺序的第(前)k个数的问题.

2.10 用最少次数寻找数组中的最大值和最小值[find min max of array]

[本文链接] http://www.cnblogs.com/hellogiser/p/find-min-max-of-array.html [题目] 对于一个由N个整数组成的数组,需要比较多少次才能把最大和最小的数找出来呢? [分析] 1. 遍历两次数组,分别找出最大值和最小值,需要进行 2N 次比较. 2. 将数组中的元素分组,按顺序将数组中相邻的两个数分在同一组,用Max和Min来存储最大值和最小值.同一组比较完之后,较小的数与当前的最小值比较,如该数小于当前最小值,更新Min:较大的数与当

找到数组中唯一重复的数

#include<iostream> #include<algorithm> #include<numeric> using namespace std; int helper1(int a[],int n) { int sum = accumulate(a,a+n,0); int sum2 = n*(n-1)/2; return sum-sum2; } int helper2(int a[],int n) { int bitor = a[0]^0; for(int i