博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
3Sum Smaller
阅读量:6907 次
发布时间:2019-06-27

本文共 970 字,大约阅读时间需要 3 分钟。

3Sum Smaller

题目链接:

  1. sort,从小到大排序

  2. 固定第一个数字index = i,从后面的数字里选第二个第三个

  3. 后两个数字,用2 points来找,从j = i + 1, k = len() - 1开始:

    • if n[j] + n[k] < target - n[i]: count += (k-i), j++

      因为所有(j+1, k)之间的数和n[j]组合都< target - n[i]

    • if n[j] + n[k] >= target - n[i]: k--

public class Solution {    public int threeSumSmaller(int[] nums, int target) {        if(nums == null || nums.length < 3) return 0;        // sort first        Arrays.sort(nums);        /* enumerate 1st num: k         * 2 points find 2nd, 3rd         * initial: i = k + 1, j = len(nums) - 1         * case 1: n[i] + n[j] < target - n[k]: count += j - i, i++         * case 2: > : j--         */        int count = 0;        for(int k = 0; k < nums.length - 2; k++) {            int i = k + 1, j = nums.length - 1;            while(i < j) {                if(nums[i] + nums[j] >= target - nums[k]) j--;                else {                    count += j - i;  i++;                }            }        }        return count;    }}

转载地址:http://befcl.baihongyu.com/

你可能感兴趣的文章
教你在Docker上不到2分钟建立一个多模型数据库!
查看>>
网络编程
查看>>
zookeeper选举机制
查看>>
python输入输出语句
查看>>
无法连接LINUX中的MYSQL
查看>>
HTTPS时代的到来是大势所趋!阿里云CDN如何助力企业网站进入HTTPS时代
查看>>
Linux 积极使用swap空间
查看>>
安装zibbix
查看>>
设计缓存系统该注意的问题
查看>>
svn服务器搭建
查看>>
[官方翻译]RabbitMQ生产上线前准备
查看>>
Haskell开发以太坊智能合约
查看>>
C++除零异常
查看>>
css的兼容问题汇总
查看>>
android apk 防止反编译技术第五篇-完整性校验(转)
查看>>
ios优秀开发者笔记汇总
查看>>
CSS 异步加载技术 不影响页面渲染
查看>>
我的友情链接
查看>>
angular学习资源
查看>>
我的友情链接
查看>>