算法练习之两数之和详解编程语言

最近在学习java,但是对于数据操作那部分还是不熟悉

因此决定找几个简单的算法写,用php和java分别实现

给定一个整数数组 nums 和一个目标值 target,请你在该数组中找出和为目标值的那 两个 整数,并返回他们的数组下标。

你可以假设每种输入只会对应一个答案。但是,不能重复利用这个数组中同样的元素。

示例:

给定 nums = [2, 7, 11, 15], target = 9 
 
因为 nums[0] + nums[1] = 2 + 7 = 9 
所以返回 [0, 1]

java

class Solution { 
    public int[] twoSum(int[] nums, int target) { 
        int[] rs=new int[]{0,0}; 
        for(int i=0;i<nums.length-1;i++){ 
            for(int j=i+1;j<nums.length;j++){ 
                if(nums[i]+nums[j]==target){ 
                    rs=new int[]{i,j}; 
                } 
            } 
        } 
        return rs; 
    } 
}

测试

import java.util.Arrays; 
 
public class Main { 
    public static void main(String[] args) { 
        Solution ss = new Solution(); 
        int[] xx = new int[]{2, 7, 11, 15}; 
        int[] yy = ss.twoSum(xx,9); 
        System.out.println("twoSum----"+ Arrays.toString(yy)); 
    } 
}

php

class Solution { 
 
    /** 
     * @param Integer[] $nums 
     * @param Integer $target 
     * @return Integer[] 
     */ 
    function twoSum($nums, $target) { 
        $rs=[]; 
        for($i=0;$i<count($nums)-1;$i++){ 
            for($j=$i+1;$j<count($nums);$j++){ 
                if($nums[$i]+$nums[$j]==$target){ 
                    $rs[0]=$i; 
                    $rs[1]=$j; 
                } 
            } 
        } 
        return $rs; 
    } 
}

原创文章,作者:奋斗,如若转载,请注明出处:https://blog.ytso.com/tech/pnotes/20364.html

(0)
上一篇 2021年7月19日 23:21
下一篇 2021年7月19日 23:21

相关推荐

发表回复

登录后才能评论