zoukankan      html  css  js  c++  java
  • 3 sum closest

    Given an array S of n integers, find three integers in S such that the sum is closest to a given number, target. Return the sum of the three integers. You may assume that each input would have exactly one solution.

        For example, given array S = {-1 2 1 -4}, and target = 1.
    
        The sum that is closest to the target is 2. (-1 + 2 + 1 = 2).

    找到数组中跟目标数最接近的三个数的和 。

    这里也是三个数的和问题,经过上一题三个数的和,这一题结果只有一个,也会有重复数字出现,需要处理,当然了,这里只要找到近似的和,不处理重复不影响结果。。
    这里也是遍历数组,然后在剩下的数组中依次遍历(两端向中间),每次遍历都会产生一个三数之和,如果该和大于target,则需要右边指针向左移动,反之左边向右移动。同时也要判断此时的和与target之间的距离跟result与target之间距离的大小。

    class Solution {
        public int threeSumClosest(int[] nums, int target) {
            /**
            这里也是三个数的和问题,经过上一题三个数的和,这一题结果只有一个,也会有重复数字出现,需要处理,当然了,这里只要找到近似的和,不处理重复不影响结果。。
            这里也是遍历数组,然后在剩下的数组中依次遍历(两端向中间),每次遍历都会产生一个三数之和,如果该和大于target,则需要右边指针向左移动,反之左边向右移动。同时也要判断此时的和与target之间的距离跟result与target之间距离的大小。
            
            */
            //初始一个三个元素的和的变量,下面计算三个数的和时要和这个以及target之间的差值作比较
            int result=nums[0]+nums[1]+nums[nums.length-1];
            Arrays.sort(nums);
           
            
            
            for(int i=0;i<nums.length-2;i++){
                
                    //两个数的和与sum最接近就行
                    int left=i+1,right=nums.length-1;
                    while(left<right){
                       int sum=nums[i]+nums[left]+nums[right];
                        if(sum>target) right--;
                        else left++;
                        if(Math.abs(result-target)>Math.abs(sum-target))
                            result=sum;
                        
                    }
                
            }
            return result;
           
        }
    }
    
    
  • 相关阅读:
    cookie和session。
    K3cloud Web API对接---单据保存接口(有源单)
    K3 wise kis 防火墙设置
    新单序时簿插件
    mssqlserver中排序规则冲突的问题解决
    读取金蝶图片
    金蝶wise委外订单关闭简述
    存储过程加锁
    判断存储过程是否存在
    解除死锁
  • 原文地址:https://www.cnblogs.com/xiaolovewei/p/8109770.html
Copyright © 2011-2022 走看看