一、1两数之和

二、15三数之和

C++ Soution 1:

 class Solution {
 public:
     vector<vector<int>> threeSum(vector<int>& nums)
     {
         vector<vector<int>> res;
         sort(nums.begin(), nums.end());
         ; k < nums.size(); ++k)
         {
             )
                 break;
              && nums[k] == nums[k - ])
                 continue;
              - nums[k];
             , j = nums.size() - ;
             while (i < j)
             {
                 if (nums[i] + nums[j] == target)
                 {
                     res.push_back({nums[k], nums[i], nums[j]});
                     ])
                         ++i;
                     ])
                         --j;
                     ++i;
                     --j;
                 }
                 else if (nums[i] + nums[j] < target)
                     ++i;
                 else
                     --j;
             }
         }
         return res;
     }
 };

  

三、16最接近的三数之和

题目:3Sum Closest

C++ Soution 1:

 class Solution {
 public:
     int threeSumClosest(vector<int>& nums, int target)
     {
         ] + nums[] + nums[];
         int diff = abs(closest - target);
         sort(nums.begin(), nums.end());
         ; i < nums.size() - ; ++i)
         {
             , right = nums.size() - ;
             while (left < right)
             {
                 int sum = nums[i] + nums[left] + nums[right];
                 int newDiff = abs(sum - target);
                 if (diff > newDiff)
                 {
                     diff = newDiff;
                     closest = sum;
                 }
                 if (sum < target)
                     ++left;
                 else
                     --right;
             }
         }
         return closest;
     }
 };

四、18四数之和

题目:4Sum

C++ Soution 1:

 class Solution {
 public:
     vector<vector<int>> fourSum(vector<int>& nums, int target)
     {
         vector<vector<int>> res;
         sort(nums.begin(), nums.end());
         if(nums.empty())
             return {};
         ; k < nums.size(); ++k)
         {
              && nums[k] == nums[k-])
                 continue;
             ; m < nums.size(); ++m)
             {
                 int sum = target - nums[k] -nums[m];
                  && nums[m] == nums[m -])
                     continue;
                 , j = nums.size() -;
                 while(i < j)
                 {
                     if(sum == nums[i] + nums[j])
                     {
                         res.push_back({nums[k], nums[m], nums[i], nums[j]});
                         ])
                             ++i;
                         ])
                             --j;
                         ++i;
                         --j;
                     }
                     else if(sum > nums[i] + nums[j])
                         ++i;
                     else
                         --j;
                 }
             }
         }
         return res;
     }
 };

五. 平方数之和

题目:633. Sum of Square Numbers

C++ Soution 1:双指针

 class Solution {
 public:
     bool judgeSquareSum(int c)
     {
         ;
         long long high = sqrt(c);
         while (low < high)
         {
             if (low*low + high * high == c)
                 return true;
             else if (low*low + high * high > c)
                 high--;
             else
                 low++;
         }
         return false;
     }
 };

367. 有效的完全平方数

题目:367. Valid Perfect Square

C++ Soution 1:

 class Solution {
 public:
     bool isPerfectSquare(int num)
     {
         ) return true;

         , right = num;//高低指针
         long long mid;
         while (left <= right)
         {
             mid = (left + right) / ;
             long long target = mid  * mid ; //防止超出int
             if (target == num)
                 return true;
             else if (target > num)
                 right = mid - ;  //大了,就降低高指针
             else
                 left = mid + ; //小了,升高低指针
         }
         return false;
     }
 };

50. Pow(x, n)

题目:Pow(x, n)

C++ Soution 1:

分析:迭代的解法,我们让i初始化为n,然后看i是否是2的倍数,是的话x乘以自己,否则res乘以x,i每次循环缩小一半,直到为0停止循环。最后看n的正负,如果为负,返回其倒数

 class Solution {
     public:
     double myPow(double x, int n)
     {
         double res = 1.0;
         ; i /= )
         {
              != )
                 res *= x;
             x *= x;
         }
          ?  / res : res;
     }
 };

【Leetcode | 5】求和问题的更多相关文章

  1. leetcode 二进制求和 python

    class Solution: def addBinary(self, a, b): """ :type a: str :type b: str :rtype: str ...

  2. 求和问题总结(leetcode 2Sum, 3Sum, 4Sum, K Sum)

    转自  http://tech-wonderland.net/blog/summary-of-ksum-problems.html 前言: 做过leetcode的人都知道, 里面有2sum, 3sum ...

  3. [LeetCode] Design Excel Sum Formula 设计Excel表格求和公式

    Your task is to design the basic function of Excel and implement the function of sum formula. Specif ...

  4. (leetcode:选择不相邻元素,求和最大问题):打家劫舍(DP:198/213/337)

    题型:从数组中选择不相邻元素,求和最大 (1)对于数组中的每个元素,都存在两种可能性:(1)选择(2)不选择,所以对于这类问题,暴力方法(递归思路)的时间复杂度为:O(2^n): (2)递归思路中往往 ...

  5. LeetCode 40 Combination Sum II(数组中求和等于target的所有组合)

    题目链接:https://leetcode.com/problems/combination-sum-ii/?tab=Description   给定数组,数组中的元素均为正数,target也是正数. ...

  6. LeetCode 39 Combination Sum(满足求和等于target的所有组合)

    题目链接: https://leetcode.com/problems/combination-sum/?tab=Description   Problem: 给定数组并且给定一个target,求出所 ...

  7. LeetCode总结 -- 树的求和篇

    树的求和属于树的题目中比較常见的,由于能够有几种变体,灵活度比較高,也能够考察到对于树的数据结构和递归的理解. 一般来说这些题目就不用考虑非递归的解法了(尽管事实上道理是跟LeetCode总结 -- ...

  8. LeetCode:二进制求和【67】

    LeetCode:二进制求和[67] 题目描述 给定两个二进制字符串,返回他们的和(用二进制表示). 输入为非空字符串且只包含数字 1 和 0. 示例 1: 输入: a = "11" ...

  9. LeetCode:范围求和||【598】

    LeetCode:范围求和||[598] 题目描述 给定一个初始元素全部为 0,大小为 m*n 的矩阵 M 以及在 M 上的一系列更新操作. 操作用二维数组表示,其中的每个操作用一个含有两个正整数 a ...

  10. LeetCode解题报告--2Sum, 3Sum, 4Sum, K Sum求和问题总结

    前言: 这几天在做LeetCode 里面有2sum, 3sum(closest), 4sum等问题, 这类问题是典型的递归思路解题.该这类问题的关键在于,在进行求和求解前,要先排序Arrays.sor ...

随机推荐

  1. eMMC基础技术7:Bus Speed Modes

    1. 前言 eMMC有多种速率模式,主要根据如下几个方面进行划分: single rate or dual rate I/O电压 BUS宽度 支持的clock频率范围 最大的传输速率 2. 概览 图 ...

  2. 专题:CF图论杂题

    题目是来自HZW的博客(构造题我是各种不会...) Solved 1 / 1 A CodeForces 500A New Year Transportation Solved 1 / 1 B Code ...

  3. Unity3D ParticleSystem粒子系统

    粒子系统检视面板 点击粒子系统检视面板的右上角的"+"来增加新的模块.(Show All Modules:显示全部) 初始化模块: 持续时间(Duration):粒子系统发射粒子的 ...

  4. in exists

    区别及应用场景 in 和 exists的区别: 如果子查询得出的结果集记录较少,主查询中的表较大且又有索引时应该用in, 反之如果外层的主查询记录较少,子查询中的表大,又有索引时使用exists.其实 ...

  5. 将C注册到lua环境中使用

    注册到lua的方式有两种,一种是lua解释器,如果支持动态链接,使用动态链接机制,将函数接口编译成动态链接库,然后将动态链接库放到lua的C路径(LUA_CPATH)中,然后在lua文件中直接使用 r ...

  6. SSL For Free 申请免费https SSL 凭证

    打开 SSL For Free网站(https://www.sslforfree.com) ,在输入框中填入你要申请 Let’s Encrypt 凭证的网域名称,可以用空白来分隔不同的网址,例如[su ...

  7. Razor视图基本语法

    <!--Razor C#--> @for (int i = 0; i < 10; i++) {     <baobao>good</baobao> } < ...

  8. freeswitch反注册记录

    应用情景: 使用阿里服务器,落地使用本地的模拟线路(O口网关). 1.FreeSWITCH 服务器开一个账号,比如 5000 internal , O口 SIP设置页面按照网关注册 5000 的账号信 ...

  9. Spring与Quartz实现定期任务

    <!-- 任务调度测试实现一 : 自定义的任务对象com.bocloud.equipment.test.ExampleJob 必须继承QuartzJobBean类,实现抽象方法executeIn ...

  10. GDOI2018 滑稽子图 [斯特林数,树形DP]

    传送门并没有 思路 见到那么小的\(k\)次方,又一次想到斯特林数. \[ ans=\sum_{T} f(T)^k = \sum_{i=0}^k i!S(k,i)\sum_{T} {f(T)\choo ...