算法练习之两数之和

最近在学习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;
    }
}

 

posted @ 2019-05-13 09:05  慕尘  阅读(137)  评论(0编辑  收藏  举报