forked from gzc/CLRS
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathsecond-smallest.cpp
90 lines (81 loc) · 2.19 KB
/
second-smallest.cpp
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
/*************************************************************************
> File Name: second-smallest.cpp
> Author: Louis1992
> Mail: [email protected]
> Blog: http://gzc.github.io
> Created Time: Sun May 24 09:32:14 2015
************************************************************************/
#include<iostream>
#include<queue>
using namespace std;
struct Node
{
int v;
Node *left;
Node *right;
bool dir; // 0 mean left, 1 mean right
Node() : v(-1),left(nullptr),right(nullptr){}
Node(int _v, bool d) : v(_v),left(nullptr),right(nullptr),dir(d){}
};
int second_smallest_element(int arr[], int n)
{
queue<Node*> q;
for(int i = 0;i < n;i++)
{
Node *new_node = new Node(arr[i], 0);
q.push(new_node);
}
Node *root(nullptr);
while(!q.empty())
{
int size = q.size();
if(size == 1)
{
root = q.front();
break;
}
for(int i = 0;i < size;i += 2)
{
if(i == size - 1)
{
Node *n1 = q.front(); q.pop();
q.push(n1);
break;
} else {
Node *n1 = q.front(); q.pop();
Node *n2 = q.front(); q.pop();
int smaller = 0;
bool dir;
if(n1 -> v <= n2 -> v)
{
smaller = n1->v;
dir = false;
} else {
smaller = n2->v;
dir = true;
}
Node *new_node = new Node(smaller,dir);
new_node->left = n1;
new_node->right = n2;
q.push(new_node);
}
}
}
int minium = root->v;
int result(INT_MAX);
while(root)
{
if(root->left && root->right)
{
result = min( (root->left->v ^ root->right->v ^ minium), result);
root = root->dir == true ? root->right : root->left;
} else break;
}
return result;
}
int main() {
int arr[8] = {3,4,1,0,7,-2,-10,100};
int result = second_smallest_element(arr, 8);
cout << result << endl;
return 0;
}