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

谷歌不收录网站山东阳信建设局网站

谷歌不收录网站,山东阳信建设局网站,有哪些网络推广平台,足球网页制作模板题目: 给你一个整数数组 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.yayakq.cn/news/482130/

相关文章:

  • 百度包头网站建设wordpress首页表单
  • 苏州高端网站建设公司哪家好wordpress怎么弄中文
  • 湛江网站模板html5建设的网站
  • 网站开发商标属于哪一类公司app开发
  • 重庆微信网站作公司建设银行网站怎么登录密码
  • 网站做ssl证书有风险德阳吧网站建设
  • 如何建设网站论文文献门户网站建设的书籍
  • 对网站开发的理解wordpress付费阅读插件
  • 四川网站建设广元分公司景区官方网站建设方案
  • 物流企业的网站模板网站黄金比例
  • 秦皇岛做网站的公司有哪些无锡百度
  • 做企业网站用哪个cms网站开发包含上线吗
  • 乌审旗建设局网站四川省工程造价总站官网
  • 山东网站建设系统毕业设计网站建设
  • 上海建设门户网站wordpress钉钉登陆
  • 网站建设相关标准iis建站安装wordpress
  • 汕头网站排名推广360免费建站官网
  • 云梦县城乡建设局网站wordpress购物车
  • 株洲建设网站制作福田欧曼前四后八新车报价
  • 购买网站服务器做网站网站建设
  • 部门门户网站建设请示桂林手机网站建设
  • wordpress不用php无锡seo优化
  • 网站建设越来越难做网络推广的基本方法有哪些
  • 娱乐网站制作网站建设怎么接单
  • 网站是别人做的我这就没有根目录计算机培训班价格
  • 网站设计的技术选择北京手机建站模板
  • 网站如何生成二维码wordpress 发布慢
  • 将自己做的网站发布到wordpress登录页名
  • 网站建设图片怎么调小俊哥网站建设
  • 优化网站seo策略自助建站源码php