两数之和,当找到一个后,需要break!

和为S的两个数字

http://www.nowcoder.com/questionTerminal/390da4f7a00f44bea7c2f3d19491311b

双指针,因为两个数,所以终止条件为while(left<right)

    /**
     * 输入一个递增排序的数组和一个数字S,在数组中查找两个数,
     * 使得他们的和正好是S,
     * 如果有多对数字的和等于S,输出两个数的乘积最小的。
     * @param array 递增排序的数组
     * @param sum 和
     * @return 两个数,使得他们的和正好是S
     */
    public ArrayList<Integer> FindNumbersWithSum(int [] array,int sum) {
        ArrayList<Integer> res=new ArrayList<>(2);
        if(array==null||array.length==0||array[0]>sum){
            return res;
        }
        int start=0,end=array.length-1;
        int nSum=0;
        while (start<end){
            nSum=array[start]+array[end];
            if(nSum>sum){
                end--;
            }else if(nSum<sum){
                start++;
            }else{
                //找到一个
                res.add(start);
                res.add(end);
                break;
            }

        }
        return res;

    }
全部评论

相关推荐

10-25 23:12
门头沟学院 Java
点赞 评论 收藏
分享
点赞 收藏 评论
分享
牛客网
牛客企业服务