• 双指针---有序数组的TWO SUM


      双指针思想,主要用于遍历数组,两个指针指向不同的元素,从而协同完成任务。

    有序数组的 Two Sum

    Leetcode :167. Two Sum II - Input array is sorted (Easy)

    Input: numbers={2, 7, 11, 15}, target=9
    Output: index1=1, index2=2
    

    题目描述:

      在有序数组中找出两个数,使他们的和为target。

    思路分析:

      使用双指针,一个指针指向较小的元素,一个指向较大的元素,指向较小的元素的指针从左到右进行遍历,指向较大的元素的指针从右向左进行遍历。

      如果两个指针指向的元素和sum==target,那么得到要求的结果。

      如果sum>target,移动较大的元素,使sum变小一些;

      如果sum<target,移动较大的元素,使sum变大一些;

    代码:
    public int[]twoSum(int []nums,int target){
        if(nums==null||nums.length<2)
            return null;
        int []res=new int [2];
        int small=0;
        int big=nums.length-1;
        while(small<big){
            if(nums[small]+nums[big]==target){
                res[0]=small+1;
                res[1]=big+1;
                return res;
            }else if(nums[small]+nums[big]<target){
                small++;
            }else{
                big--;
            }
        }
        return null
    }
    
  • 相关阅读:
    Java IO总结
    Tomcat处理一个HTTP请求的过程
    Tomcat的web项目部署方式
    Tomcat性能调优
    jquery基础知识汇总
    Javascript中的正则表达式
    HTTP首部
    HTTPS
    Javascript中关于cookie的那些事儿
    HTTP请求方法详解
  • 原文地址:https://www.cnblogs.com/yjxyy/p/11104369.html
Copyright © 2020-2023  润新知