给定一个数组, 有一个数是重复的,找到这个数,要求时间复杂度是O(N),空间复杂度不能超过O(N)
很简单,自己当时老往排序上面想了..
#include <iostream>
#include <vector>
#include <algorithm>
using namespace std;
int main()
{
int arr[] = {1, 2, 3, 5, 5, 6, 7, 8};
int len = sizeof(arr)/sizeof(*arr);
vector<int> v;
for(int i = 0; i < len; i++)
{
vector<int>::iterator it = find(v.begin(), v.end(), arr[i]);
if(it != v.end())
{
cout<<"the same number is "<<arr[i] <<endl;
}
else
{
v.push_back(arr[i]);
}
}
return 0;
}