zoukankan      html  css  js  c++  java
  • LeetCode

     15. 3Sum

    Problem's Link

     ----------------------------------------------------------------------------

    Mean: 

    给定一个数列,找出这个数列中和为0的三元组.

    analyse:

    时间复杂度:O(n^2)

    思路很简单,注意一下去重的方法.

    Time complexity: O(N)

     

    view code

    /**
    * -----------------------------------------------------------------
    * Copyright (c) 2016 crazyacking.All rights reserved.
    * -----------------------------------------------------------------
    *       Author: crazyacking
    *       Date  : 2016-02-16-17.21
    */
    #include <queue>
    #include <cstdio>
    #include <set>
    #include <string>
    #include <stack>
    #include <cmath>
    #include <climits>
    #include <map>
    #include <cstdlib>
    #include <iostream>
    #include <vector>
    #include <algorithm>
    #include <cstring>
    using namespace std;
    typedef long long(LL);
    typedef unsigned long long(ULL);
    const double eps(1e-8);

    class Solution
    {
    public:
       vector<vector<int> > threeSum(vector<int>& nums)
       {
           int si=nums.size();
           vector<vector<int> > ret;
           sort(nums.begin(),nums.end());
           int target,sum,low,high;
           for(int i=0;i<si;i++)
           {
               target=-nums[i];
               low=i+1;
               high=si-1;
               // not exist two active integet's sum greater than target
               if(target<0)
                   break;

               while(low<high)
               {
                   sum=nums[low]+nums[high];
                   if(sum<target)
                       ++low;
                   else if(sum>target)
                       --high;
                   else
                   {
                       vector<int> triple(3,0);
                       triple[0]=nums[i];
                       triple[1]=nums[low];
                       triple[2]=nums[high];
                       ret.push_back(triple);
                       while(low<high && triple[1]==nums[low]) ++low;
                       while(low<high && triple[2]==nums[high]) --high;
                   }
               }
               while(i+1 < nums.size() && nums[i+1] == nums[i])
                   ++i;
           }
           return ret;
       }
    };

    int main()
    {
       Solution solution;
       int n;
       while(cin>>n)
       {
           vector<int> ve;
           for(int i=0;i<n;++i)
           {
               int tmp;
               cin>>tmp;
               ve.push_back(tmp);
           }
           vector<vector<int> > ans;
           ans=solution.threeSum(ve);
           for(auto p1:ans)
           {
               for(auto p2:p1)
                   cout<<p2<<" ";
               cout<<endl;
           }
       }
       return 0;
    }
  • 相关阅读:
    超赞!推荐一个专注于Java后端源码分析的Github项目!
    SpringApplication对象是如何构建的? SpringBoot源码(八)
    Java是如何实现自己的SPI机制的? JDK源码(一)
    SpringBoot的启动流程是怎样的?SpringBoot源码(七)
    SpringBoot内置的各种Starter是怎样构建的?--SpringBoot源码(六)
    外部配置属性值是如何被绑定到XxxProperties类属性上的?--SpringBoot源码(五)
    SpringBoot是如何实现自动配置的?--SpringBoot源码(四)
    设计模式目录
    桥接模式
    常见的HTTP状态码
  • 原文地址:https://www.cnblogs.com/crazyacking/p/5038583.html
Copyright © 2011-2022 走看看