leetcode刷题分享:15. 三数之和

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

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

思路不难想,可以先排好序然后三指针移动找到和为0,这道题最有意思的地方在于它要求你把握好去重,nums[i], nums[j], nums[k]的去重。只要小心这一点这道题就不难解了。 附一份菜鸡代码。

class Solution {
public List<List<Integer>> threeSum(int[] nums) {
    if(nums.length==0) return new ArrayList<>();
    List<List<Integer>> res=new ArrayList<>();
    Arrays.sort(nums);
    for(int i=0;i<nums.length-2;i++){
        if(i>0&&nums[i]==nums[i-1]) {
            continue;
        }
        int l=i+1,r=nums.length-1;
        while(l<r){
            int sum=nums[i]+nums[l]+nums[r];
            if(sum==0){
                res.add(new ArrayList<>(List.of(nums[i],nums[l],nums[r])));
                while(l<r&&nums[l]==nums[l+1]){
                    l++;
                }
                while (l<r&&nums[r]==nums[r-1]){
                    r--;
                }
                l++;
                r--;
            }
            else if(sum<0){
                l++;
            }
            else{
                r--;
            }
        }
    }
    return res;
}

}

#笔试#
全部评论

相关推荐

模块泄露(module&nbsp;leaks)通常指的是在应用程序或库中,某个模块的资源(变量、函数、类等)在不恰当的情况下被暴露或泄露给了其他模块或作用域,导致数据的不受控制的共享或污染。以下是一些可能导致模块泄露的情况:https://www.nowcoder.com/issue/tutorial?zhuanlanId=Mg58Em&amp;uuid=ba06d8fbb87f45f7bf340c85dc4f0cc1全局变量污染:如果在模块中将变量或函数定义在全局作用域中,其他模块就可以直接访问和修改这些变量,从而导致不受控制的共享和污染。意外的导出:当一个模块中的变量、函数或类被意外地导出给了其他模块使用,而不是作为内部实现的一部分,就可能导致模块泄露。这可能是由于代码编写错误、导入导出配置问题或误操作导致的。循环引用:循环引用是指两个或多个模块相互之间存在着相互依赖的关系。如果循环引用的处理不当,可能导致模块无法正确加载或导致模块之间的依赖关系混乱,从而导致模块泄露。模块泄露的后果可能包括代码的不稳定性、变量冲突、内存泄露等。为了避免模块泄露,可以采取以下措施:封装和隐藏内部实现:在设计模块时,合理使用作用域和闭包,仅暴露必要的接口给其他模块使用,将内部实现状态和方法进行封装和隐藏,减少模块间的直接依赖和冲突。使用模块化的开发方式:使用模块化的开发方式,如CommonJS、ES&nbsp;Modules等,可以通过明确的导入和导出规范来管理模块之间的依赖关系,避免意外的导出和导入问题。严格限制全局变量的使用:尽量避免使用全局变量,将变量的作用域限制在模块内部,避免变量的污染和共享。检查循环引用:在使用模块间的相互依赖时,保持谨慎,并检查循环引用问题。可以通过工具、插件或规范来检查和处理循环引用的情况。通过以上的措施,可以有效地减少模块泄露的发生,并提高代码的健壮性和可维护性。
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客企业服务