zoukankan      html  css  js  c++  java
  • LeetCode: 4Sum

    跟3sum和3sum closest差不多

    C++:

     1 class Solution {
     2  public:
     3      vector<vector<int> > fourSum(vector<int> &num, int target) {
     4          // Start typing your C/C++ solution below
     5          // DO NOT write int main() function
     6          vector<vector<int>> ret;
     7          if (num.size() < 4) return ret;
     8          sort(num.begin(), num.end());
     9          for (int i = 0; i < num.size()-3; i++) {
    10              if (i > 0 && num[i] == num[i-1]) continue;
    11              for (int j = i+1; j < num.size()-2; j++) {
    12                  if (j > i+1 && num[j] == num[j-1]) continue;
    13                  int end = num.size()-1;
    14                  for (int beg = j+1; beg < end; beg++) {
    15                      if (beg > j+1 && num[beg] == num[beg-1]) continue;
    16                      int sum = num[i] + num[j] + num[beg] + num[end];
    17                      if (sum == target) {
    18                          vector<int> tmp;
    19                          tmp.push_back(num[i]);
    20                          tmp.push_back(num[j]);
    21                          tmp.push_back(num[beg]);
    22                          tmp.push_back(num[end]);
    23                          ret.push_back(tmp);
    24                      }
    25                      else if (sum > target) end--, beg--;
    26                  }
    27              }
    28          }
    29          return ret;
    30      }
    31  };

    java:

     1 public class Solution {
     2     public List<List<Integer>> fourSum(int[] nums, int target) {
     3         List<List<Integer>> ans = new ArrayList<List<Integer>>();
     4         Arrays.sort(nums);
     5         for (int i = 0; i < nums.length; i++) 
     6         {
     7             if (i > 0 && nums[i] == nums[i-1]) continue;
     8             for (int j = i+1; j < nums.length; j++)
     9             {
    10                 if (j > i+1 && nums[j] == nums[j-1]) continue;
    11                 int left = j+1;
    12                 int right = nums.length-1;
    13                 while (left < right)
    14                 {
    15                     if (left > j+1 && nums[left] == nums[left-1]) {
    16                         left++;
    17                         continue;
    18                     }
    19                     int sum = nums[i] + nums[j] + nums[left] + nums[right];
    20                     if (sum == target) {
    21                         List<Integer> tmp = new ArrayList<Integer>();
    22                         tmp.add(nums[i]);
    23                         tmp.add(nums[j]);
    24                         tmp.add(nums[left]);
    25                         tmp.add(nums[right]);
    26                         ans.add(tmp);
    27                         left++;
    28                     }
    29                     else if (sum < target) left++;
    30                     else right--;
    31                 }
    32             }
    33         }
    34         return ans;
    35     }
    36 }
    View Code
  • 相关阅读:
    读《大道至简》有感
    软件工程概论第一次课堂作业
    课后小程序
    继承与多态课后作业
    课后作业2-字符串
    课后作业1:字串加密
    3-类与对象-动手动脑
    使用类的静态字段和构造函数,跟踪某个类所创建对象的个数。
    课程作业02-1-课后作业1-(3、4)汉诺塔、回文数
    课程作业02-2-动手动脑
  • 原文地址:https://www.cnblogs.com/yingzhongwen/p/2960680.html
Copyright © 2011-2022 走看看