-
Notifications
You must be signed in to change notification settings - Fork 1
/
42_找出这两个只出现一次的数字
135 lines (129 loc) · 2.06 KB
/
42_找出这两个只出现一次的数字
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
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
#include <iostream>
#include <vector>
using namespace std;
/*
题目描述
一个整型数组里除了两个数字之外,其他的数字都出现了两次。请写程序找出这两个只出现一次的数字。
*/
class Solution
{
public:
//方法1:用哈希
void FindNumsAppearOnce(vector<int> data, int* num1, int *num2)
{
vector<int> hash;
int max = data[0];
int min = data[0];
int sz = data.size();
for (int i = 0; i < sz; ++i)
{
if (max < data[i])
{
max = data[i];
}
if (min > data[i])
{
min = data[i];
}
}
int HashSize = max - min + 1;
hash.resize(HashSize);
for (int i = 0; i < sz; ++i)
{
++hash[data[i] - min];
}
for (int i = 0; i < HashSize; ++i)
{
if (hash[i] == 1)
{
if (!*num1)
{
*num1 = i + min;
}
else
{
*num2 = i + min;
return;
}
}
}
*num2 = 0;
}
//方法2 用异或
void FindNumsAppearOnce_2(vector<int> data, int *num1, int *num2)
{
if (data.size() < 2)
{
return;
}
int val = data[0];
for (int i = 1; i < data.size(); ++i)
{
val ^= data[i];
}
int count = 0;
int num = 1;
while ((val & num) == 0)
{
num <<= 1;
++count;
}
int pos = 1;
while (count--)
{
pos <<= 1;
}
vector<int> v1;
vector<int> v2;
for (int &i : data)
{
if ((i & pos) == 0) //注意优先级
{
v1.push_back(i);
}
else
{
v2.push_back(i);
}
}
//再分别找
int val1 = v1[0];
int val2 = v2[0];
for (int i = 1; i < v1.size(); ++i)
{
val1 ^= v1[i];
}
*num1 = val1;
for (int i = 1; i < v2.size(); ++i)
{
val2 ^= v2[i];
}
*num2 = val2;
}
};
void Test()
{
vector<int> viec = { 2, 4, 3, 6, 3, 2, 5, 5 };
int a = 0;
int b = 0;
int *p1 = &a;
int *p2 = &b;
Solution().FindNumsAppearOnce(viec, p1, p2);
cout << *p1 << " " << *p2 << endl;
}
void Test1()
{
vector<int> viec = { 2, 4, 3, 6, 3, 2, 5, 5 };
int a = 0;
int b = 0;
int *p1 = &a;
int *p2 = &b;
Solution().FindNumsAppearOnce_2(viec, p1, p2);
cout << *p1 << " " << *p2 << endl;
}
int main()
{
//Test();
Test1();
return 0;
}