精通算法系列-三值更小
来源:互联网 发布:spss软件安装 编辑:程序博客网 时间:2024/05/21 09:25
原题:
// Given an array of n integers nums and a target, find the number of index triplets i, j, k with 0 <= i < j < k < n that satisfy the condition nums[i] + nums[j] + nums[k] < target.// For example, given nums = [-2, 0, 1, 3], and target = 2.// Return 2. Because there are two triplets which sums are less than 2:// [-2, 0, 1]// [-2, 0, 3]// Follow up: // Could you solve it in O(n2) runtime?
意思就是:选三个值满足0 <= i < j < k < n 且这三个值加起来没有给定的值大的数组,
答案如下:
public class Solution { public int threeSumSmaller(int[] nums, int target) { //initialize total count to zero int count = 0; //sort the array Arrays.sort(nums); //loop through entire array for(int i = 0; i < nums.length - 2; i++) { //set left to i + 1 int left = i + 1; //set right to end of array int right = nums.length - 1; //while left index < right index while(left < right) { //if the 3 indices add to less than the target increment count if(nums[i] + nums[left] + nums[right] < target) { //increment the count by the distance between left and right because the array is sorted count += right - left; //increment left pointer left++; } //if they sum to a value greater than target... else { //decrement right pointer right--; } } } return count; }}
核心思路:从左到左加1到最后开始循环,满足条件则加1
阅读全文
0 0
- 精通算法系列-三值更小
- 精通算法系列-BST
- 精通算法系列-复制图形
- 精通算法系列-二进制手表
- 精通算法系列-最佳买卖股票
- 精通算法系列-二叉树路径
- 精通算法系列-安卓屏幕锁
- 精通算法系列-二叉树问题
- 精通八大排序算法系列:二、堆排序算法
- 精通八大排序算法系列:一、快速排序算法
- 精通八大排序算法系列:二、堆排序算法
- 精通八大排序算法系列:二、堆排序算法
- 精通八大排序算法系列:一、快速排序算法 ---转csdn
- 精通八大排序算法系列:一之续、快速排序算法的深入分析
- 精通八大排序算法系列:一之续、快速排序算法的深入分析
- 精通八大排序算法系列:一之续、快速排序算法的深入分析
- 精通JavaScript系列目录
- 精通Grails系列网址
- ajax
- 对于Android的插件化(功能拆分成插件,按需加载)的了解
- Gym 101164.F
- 海量数据实时在线分析Quick BI入门
- postgresql 的三种日志
- 精通算法系列-三值更小
- JS实现web页面的导航栏时间与本地同步,实时更新!
- 【Unity Shaders】法线纹理(Normal Mapping)的实现细节 笔记
- 机器学习实战学习笔记(二)分类—ID3决策树算法(python3实现)
- opencv 04 Haar 人脸识别 vs2015
- EL表达式处理页面毫秒数
- 关于Halcon的复杂图形中心点查找
- 我是一个线程
- iPhone X在push时tabBar往上偏移的问题