三. 分析
四. 题解
1 class Solution { 2 public: 3 vector<int> twoSum(vector<int>& nums, int target) { 4 vector<int> res; 5 unordered_map<int, int> m; 6 7 for (int i = 0; i < nums.size(); i++) m[nums[i]] = i; 8 9 for (int i = 0; i < nums.size(); i++) { 10 if (m.count(target - nums[i]) && m[target - nums[i]] != i) { 11 res.push_back(i); 12 res.push_back(m[target - nums[i]]); 13 return res; 14 } 15 } 16 17 return res; 18 } 19 };
1 class Solution { 2 public: 3 vector<int> twoSum(vector<int>& B, int target) { 4 vector<int> res; 5 vector<pair<int, int>> A; 6 7 for (int i = 0; i < B.size(); i++) { 8 A.push_back(make_pair(B[i], i)); 9 } 10 11 my_qsort(A, 0, A.size() - 1); 12 13 for (int i = 0; i <= A.size(); i++) { 14 int left = i + 1, right = A.size() - 1; 15 while (left <= right) { 16 int mid = left + (right - left) / 2; 17 if (A[mid].first == target - A[i].first) { 18 res.push_back(A[i].second); 19 res.push_back(A[mid].second); 20 return res; 21 } 22 if (A[mid].first < target - A[i].first) left = mid + 1; 23 else right = mid - 1; 24 } 25 } 26 27 return res; 28 } 29 private: 30 void my_qsort(vector<pair<int, int>>& A, int l, int r) { 31 if (l > r) return; 32 33 pair<int, int> key = A[l]; 34 int nl= l, nr = r; 35 while (l < r) { 36 pair<int, int> tmp; 37 while (A[r].first >= key.first && l < r) r--; 38 while (A[l].first <= key.first && l < r) l++; 39 40 41 tmp = A[l]; 42 A[l] = A[r]; 43 A[r] = tmp; 44 } 45 A[nl] = A[l]; 46 A[l] = key; 47 48 my_qsort(A, nl, l - 1); 49 my_qsort(A, l + 1, nr); 50 } 51 };
1 class Solution { 2 public: 3 vector<int> twoSum(vector<int>& B, int target) { 4 vector<int> res; 5 vector<pair<int, int>> A; 6 7 for (int i = 0; i < B.size(); i++) { 8 A.push_back(make_pair(B[i], i)); 9 } 10 11 int left = 0, right = A.size() - 1; 12 my_qsort(A, 0, A.size() - 1); 13 14 while (left < right) { 15 if (A[left].first + A[right].first < target) left++; 16 else if (A[left].first + A[right].first > target) right--; 17 else {res.push_back(A[left].second), res.push_back(A[right].second); return res;}; 18 } 19 20 return res; 21 } 22 private: 23 void my_qsort(vector<pair<int, int>>& A, int l, int r) { 24 if (l > r) return; 25 26 pair<int, int> key = A[l]; 27 int nl= l, nr = r; 28 while (l < r) { 29 pair<int, int> tmp; 30 while (A[r].first >= key.first && l < r) r--; 31 while (A[l].first <= key.first && l < r) l++; 32 33 34 tmp = A[l]; 35 A[l] = A[r]; 36 A[r] = tmp; 37 } 38 A[nl] = A[l]; 39 A[l] = key; 40 41 my_qsort(A, nl, l - 1); 42 my_qsort(A, l + 1, nr); 43 } 44 };
[LeetCode] #1# Two Sum : 数组/哈希表/二分查找
原文:http://www.cnblogs.com/yuanzone/p/5570562.html