鱼C论坛

 找回密码
 立即注册
查看: 802|回复: 0

[技术交流] c++刷leetcode(259. 较小的三数之和)【不能用深度优先搜索】

[复制链接]
发表于 2020-4-18 14:15:22 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
本帖最后由 糖逗 于 2020-4-18 14:17 编辑

题目描述:

  1. 给定一个长度为 n 的整数数组和一个目标值 target,寻找能够使条件 nums[i] + nums[j] + nums[k] < target 成立的三元组  i, j, k 个数(0 <= i < j < k < n)。

  2. 示例:

  3. 输入: nums = [-2,0,1,3], target = 2
  4. 输出: 2
  5. 解释: 因为一共有两个三元组满足累加和小于 2:
  6.      [-2,0,1]
  7.      [-2,0,3]
  8. 进阶:是否能在 O(n2) 的时间复杂度内解决?
复制代码





  1. int threeSumSmaller(vector<int>& nums, int target) {
  2.         int res = 0;
  3.         sort(nums.begin(), nums.end());
  4.         for(int i = 0; i < nums.size(); i++){
  5.             int l = i+1, r = nums.size()-1;
  6.             while(l<r){
  7.                 int sum = nums[i] + nums[l] + nums[r];
  8.                 if(sum >= target){
  9.                     r--;
  10.                 }
  11.                 else{
  12.                     res += r-l;
  13.                     l++;
  14.                 }
  15.             }
  16.         }
  17.         return res;

  18.     }
复制代码




注意事项:
1.这道题不能用递归或是深度优先搜索的方法做,会出现重复项,且不能消除。

本帖被以下淘专辑推荐:

想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2024-4-28 08:50

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表