LeetCode关于数组中求和的题型
2016-09-26 22:56
246 查看
15. 3Sum:三数之和为0的组合
Given an array S of n integers, are there elements a, b, c in S such that a + b + c = 0? Find all unique triplets in the array which gives the sum of zero.Note: The solution set must not contain duplicate triplets.
For example, given array S = [-1, 0, 1, 2, -1, -4], A solution set is: [ [-1, 0, 1], [-1, -1, 2] ] 思路:循环法,先给数组排序->[-4,-1,-1,0,1,2],其中i,j,k三数的下标,i先为最左边的一个数,则i<n-3,此时可以根据求两数之和的方法来进行求解; 对一个有序的数组求两数之和为定值,最简单的方法为j,k分别为数组的两端,主键向中间靠拢; 具体代码如下:
import java.util.*; public class Solution { public List<List<Integer>> threeSum(int[] nums) { List<List<Integer>> lists = new ArrayList<>(); if(nums==null||nums.length==0) return lists; Arrays.sort(nums); int n = nums.length; int i=0; while(i<=n-3){ int j=i+1; int k = n-1; while(j<k){ if(nums[i]+nums[j]+nums[k]==0){ ArrayList<Integer> list = new ArrayList<Integer>(); list.add(nums[i]); list.add(nums[j]); list.add(nums[k]); lists.add(list); while(j<k&&nums[j]==nums[j+1]) j++; while(k>j&&nums[k]==nums[k-1]) k--; j++; k--; }else if(nums[i]+nums[j]+nums[k]<0){ j++; }else{ k--; } } while(i<n-1&&nums[i]==nums[i+1]) i++; i++; } return lists; } }
相关文章推荐
- 关于Java数组越界的一个诡异问题【leetcode204】
- LeetCode 303. Range Sum Query - Immutable(数组求和)
- LeetCode-3Sum -三数求和-有序数组扫描
- 关于数组操作的常见题型
- 关于数组传参的一些题型
- 树状数组关于区间修改区间求和的问题
- Longest Increasing Subsequence(最长增长子数列)-LeetCode关于数组的思路和技巧
- LeetCode 40 Combination Sum II(数组中求和等于target的所有组合)
- leetcode 560. Subarray Sum Equals K 动态规划DP子数组求和
- leetCode303. 数组范围求和 - 顺序不变
- 关于leetcode中对数组O(1)空间消耗操作的几道题
- 关于Leetcode里面求两个数组的第K值问题
- leetcode_454. 4Sum II 4个数组求和,返回和为0的所有情况的种数 数组两两相加存在map中
- leetcode 486. Predict the Winner 预测最后赢家+数组头尾部取元素求和+动态规划DP
- 关于java数组的深度思考
- 关于php中的数组操作
- 关于Excel数组赋值出错的问题, 800A03EC 错误
- 关于零长度数组
- 关于如何去除数组中重复项
- EXCEL 中自定义函数的应用(关于 XOR 在 EXCEL 中的用法 及 文本型数字求和)