Ninja technique🥷 to ACE DSA Interviews.
for(i=0,n-1)
for(j=i+1,n-1)
for(k=j+1,n-1)
a+b+c==0, cnt++
class Solution{
public:
vector<vector<int>> threeSum(vector<int> &nums){
sort(nums.begin(), nums.end());
vector<vector<int>> res;
int n = nums.size();
for (int i = 0; i < n - 2; i++){
if (i == 0 || (i > 0 && nums[i] != nums[i - 1])){
int lo = i + 1, hi = n - 1, sum = 0 - nums[i];
while (lo < hi){
if (nums[lo] + nums[hi] == sum){
vector<int> temp;
temp.push_back(nums[i]);
temp.push_back(nums[lo]);
temp.push_back(nums[hi]);
res.push_back(temp);
while (lo < hi && nums[lo] == nums[lo + 1]) lo++;
while (lo < hi && nums[hi] == nums[hi - 1]) hi--;
lo++,hi--;
}
else if (nums[lo] + nums[hi] < sum) lo++;
else hi--;
}
}
}
return res;
}
};