当前位置: 首页 > news >正文

有经验的佛山网站建设长春招聘会最新招聘时间

有经验的佛山网站建设,长春招聘会最新招聘时间,免费引流推广方法,ysl千人千色t9t9t9t9题目: 给你一个整数数组 nums ,判断是否存在三元组 [nums[i], nums[j], nums[k]] 满足 i ! j、i ! k 且 j ! k ,同时还满足 nums[i] nums[j] nums[k] 0 。请返回所有和为 0 且不重复的三元组。 注意:答案中不可以包含重复的三…

题目: 给你一个整数数组 nums ,判断是否存在三元组 [nums[i], nums[j], nums[k]] 满足 i != j、i != k 且 j != k ,同时还满足 nums[i] + nums[j] + nums[k] == 0 。请返回所有和为 0 且不重复的三元组。

注意:答案中不可以包含重复的三元组。

示例 1:

输入:nums = [-1,0,1,2,-1,-4]
输出:[[-1,-1,2],[-1,0,1]]
解释:
nums[0] + nums[1] + nums[2] = (-1) + 0 + 1 = 0 。
nums[1] + nums[2] + nums[4] = 0 + 1 + (-1) = 0 。
nums[0] + nums[3] + nums[4] = (-1) + 2 + (-1) = 0 。
不同的三元组是 [-1,0,1] 和 [-1,-1,2] 。
注意,输出的顺序和三元组的顺序并不重要。

示例 2:

输入:nums = [0,1,1]
输出:[]
解释:唯一可能的三元组和不为 0 。

示例 3:

输入:nums = [0,0,0]
输出:[[0,0,0]]
解释:唯一可能的三元组和为 0 。

思路:

逐个遍历数组,确定第一个元素后,剩下的两个数字就是和为 target - nums[i] 的两个数字了,因此将确定元素的下一个索引和target-nums[i]传给两个数相加和为某个数的函数,由该函数返回所有满足和为target-nums[i]的二维vector,将返回的结果遍历,如果结果不为空,每次循环将刚在确定的第一个数加进这个一维vector中组成一个和为0的三元组,再将这个三元组加入到vector中,在最后需要跳过第一个数组重复的情况,否则可能会出现重复的结果。

vector<vector<int>> twoSumtarget(vector<int>& nums,int start,int target) {int left = start;int right = nums.size() - 1;vector<vector<int>> res;while (left<right) {int leftnum = nums[left];int rightnum = nums[right];int sum = nums[left] + nums[right];if (sum <target) {while (left < right&&nums[left] == leftnum) {left++;}}else if (sum > target) {while (left < right && nums[right] == rightnum) {right--;}}else if(sum == target){res.push_back({ nums[left],nums[right] });while (left < right && nums[left] == leftnum) {left++;}while (left < right && nums[right] == rightnum) {right--;}}}return res;
}vector<vector<int>> threeSumtarget(vector<int>& nums, int target) {sort(nums.begin(),nums.end());int numsize = nums.size();vector<vector<int>> res;for (int i = 0; i < numsize;i++) {vector<vector<int>> tuples = twoSumtarget(nums,i+1,target-nums[i]);//如果存在满足条件的二元组,再加上nums[i]结果就是三元组for (vector<int>& tuple:tuples) {tuple.push_back(nums[i]);res.push_back(tuple);}//跳过第一个数字重复的情况,否则可能会出现重复结果while (i < numsize - 1 && nums[i] == nums[i + 1]) i++;}return res;
}int main() {vector<int> c{ -1,0,1,2,-1,4 };int target = 0;vector<vector<int>> result= threeSumtarget(c,target);for (vector<vector<int>>::iterator it = result.begin(); it != result.end();it++) {for (vector<int>::iterator pit = (*it).begin(); pit != (*it).end();pit++) {cout<<*pit<<" ";}cout << endl;}return 0;
}
http://www.laogonggong.com/news/85120.html

相关文章:

  • 深圳做网站的价格杭州网站优化排名
  • 如何更改公司网站内容html5网站赏析
  • 什么网站可以免费做护师题浙江省建设银行纪检官方网站
  • 在百度上怎么建立网站郑州建设最新消息
  • 深圳企业集团网站建设瑞安做网站建设哪家好
  • 网站建设者全国高校教师网络培训中心
  • 高端网站开发培训建设一个招聘网站的策划
  • 五华网站开发网站定位授权开启权限怎么做
  • nginx即代理又做网站seo网站文章编辑软件
  • 中山精品网站建设资讯蜀通建设集团
  • 通化网站推广怎么做自助提卡网站
  • 网站搭建工具视频wordpress压缩插件
  • 自己做的网站如何赚钱吗成品网站建设流程
  • python 网站框架wordpress 右侧最新标题字数
  • 如皋市建设局网站深圳响应式网站设计
  • 网站建设的报告企业推广软件有哪些
  • 一般网站是怎么做的wordpress yosat
  • 怎么封闭网站wordpress 精致博客
  • 富阳市网站建站宝盒是什么
  • 亿通网站建设网站需要每个城市做推广吗
  • 做公司网站找谁企业所得税5%的标准
  • 仿网站ppt怎么做网站布局和建站的区别
  • 广告网站有哪些北京市建设工程安全质量监督总站网站
  • 无极任务平台网站进入湖南百度推广公司
  • 推广联盟网站怎么做百度指数名词解释
  • 如何免费学校建网站许昌网站seo
  • 自己做电影网站违法怎样做好邯郸网站建设
  • 在线做ppt的网站源代码php做电商网站的难点
  • 做门窗的建网站怎么赚钱怎样把网站做的好看
  • 深圳网站搭建哪里找网站源码建站视频教程