15 三数之和 Medium

Problem: 15. 三数之和

文章目录

解题方法

暴力循环 + 剪枝,需要先排序再剪枝

Code

class Solution:
    def threeSum(self, nums: List[int]) -> List[List[int]]:
        # 暴力解
        n = len(nums)
        res = []
        nums.sort()
        for i in range(n - 2):
            if i > 0 and nums[i] == nums[i - 1]:
                continue
            k = n - 1
            target = -nums[i]
            for j in range(i + 1, n - 1):
                if j > i + 1 and nums[j] == nums[j - 1]:
                    continue
                while j < k and nums[j] + nums[k] > target:
                    k -= 1
                if j == k:
                    break
                if nums[j] + nums[k] == target:
                    res.append([nums[i], nums[j], nums[k]])
        
        return res
class Solution {
    public List<List<Integer>> threeSum(int[] nums) {
        Arrays.sort(nums);
        List<List<Integer>> ans = new ArrayList<>();
        int n = nums.length;
        for(int i = 0; i < n - 2; i++){
            if(i > 0 && nums[i] == nums[i - 1]){
                continue;
            }
            if(nums[i] > 0){
                continue;
            }
            for(int j = i + 1; j < n - 1; j++){
                if(j > i + 1 && nums[j] == nums[j - 1]){
                    continue;
                }
                if(nums[i] + nums[j] > 0){
                    continue;
                }
                for(int k = j + 1; k < n; k++){
                    if(nums[i] + nums[j] + nums[k] == 0){
                        List<Integer> arr = new ArrayList<>();
                        arr.add(nums[i]);
                        arr.add(nums[j]);
                        arr.add(nums[k]);
                        ans.add(arr);
                        break;
                    }
                    else if(nums[i] + nums[j] + nums[k] > 0){
                        break;
                    }
                }
            }
        }
        return ans;
    }
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
身份证正则表达式可以根据不同的位数进行匹配。对于15位身份证号码,正则表达式可以使用以下模式进行匹配:^[1-9]\d{5}\d{2}(0[1-9]|1[0-2])(0[1-9]|[1-2]\d|3[0-1])\d{3}$。对于18位身份证号码,正则表达式可以使用以下模式进行匹配:^[1-9]\d{5}(19|20)\d{2}(0[1-9]|1[0-2])(0[1-9]|[1-2]\d|3[0-1])\d{3}[\dXx]$。其中,^表示匹配输入的开始位置,$表示匹配输入的结束位置,\d表示匹配一个数字,[1-9]表示匹配除0以外的任意一个非零数字,[0-9]表示匹配任意一个数字,|表示或运算,()表示分组,[]表示字符集,{n}表示匹配前面的字符刚好出现n次,{n,}表示匹配前面的字符至少出现n次,{n,m}表示匹配前面的字符出现n到m次,[\dXx]表示匹配数字、大写字母X和小写字母x中的任意一个字符。所以,对于15位身份证号码,正则表达式的含义是:一位非零数字+六位数字地址码+两位数字年份+两位数字月份+两位数字日期+三位数字顺序码;对于18位身份证号码,正则表达式的含义是:一位非零数字+六位数字地址码+四位数字年份+两位数字月份+两位数字日期+三位数字顺序码+一位校验码。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* [15/18位身份证号码验证的正则表达式总结(详细版)](https://download.csdn.net/download/weixin_38742453/13673166)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] - *2* *3* [学习正则表达式 - 18位身份证号](https://blog.csdn.net/wzy0623/article/details/130260594)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值