1. 程式人生 > 實用技巧 >Nginx--try_files嘗試讀取檔案

Nginx--try_files嘗試讀取檔案

15. 三數之和 給你一個包含 n 個整數的陣列 nums,判斷 nums 中是否存在三個元素 a,b,c ,使得 a + b + c = 0 ?請你找出所有滿足條件且不重複的三元組。 注意:答案中不可以包含重複的三元組。 示例: 給定陣列 nums = [-1, 0, 1, 2, -1, -4], 滿足要求的三元組集合為:
[
[-1, 0, 1],
[-1, -1, 2]
]

思路:

將陣列排序,從 nums[0] 開始遍歷,a = nums[0], b = nums[1], c= nums[end]。將 b, c 向中間移動,直到三數之和為0。注意需要判重,即處理nums全為 0 的情況。時間複雜度 o(N)。

程式碼:

class Solution {
public:
    vector<vector<int>> threeSum(vector<int>& nums) {
       sort(nums.begin(), nums.end());
        int
i, len = nums.size(), left, right, sum, temp; vector<int> out; vector<vector<int>> result; for(i = 0; i<len; i++) { if(i>0&&nums[i-1]==nums[i]) continue; left = i+1; right = len-1; sum
= -nums[i]; while(left<right) { temp = nums[left]+nums[right]; if(temp<sum) { left++; } else if(temp>sum) { right--; }
else { out.clear(); out.push_back(-sum); out.push_back(nums[left]); out.push_back(nums[right]); result.push_back(out); left++; right--; //break; } } } // sort(result.begin(), result.end()); result.erase(unique(result.begin(), result.end()), result.end()); return result; } };