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;
           
        }
    }
    
    
  • 相关阅读:
    非递归实现二叉树先序、中序和后序遍历
    领益科技:Windows Server 2012 R2 强制卸载域控制器
    Zabbix调优不完全指南(https://www.jianshu.com/p/2d911d55448f)
    Linux下基础查看命令
    Linux下的快捷键
    给Linux系统新增加一块硬盘
    领益智造:Windows中的备份和还原
    领益智造:AD中修改OU下面用户的属性
    领益科技:AD中批量创建域用户(创建Mac地址账号)
    Linux常见企业面试题
  • 原文地址:https://www.cnblogs.com/xiaolovewei/p/8109770.html
Copyright © 2011-2022 走看看