给定一个数组, 有一个数是重复的,找到这个数,要求时间复杂度是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; }