算法练习之两数之和

最近在学习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 @   慕尘  阅读(137)  评论(0编辑  收藏  举报
(评论功能已被禁用)
编辑推荐:
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
阅读排行:
· 无需6万激活码!GitHub神秘组织3小时极速复刻Manus,手把手教你使用OpenManus搭建本
· C#/.NET/.NET Core优秀项目和框架2025年2月简报
· Manus爆火,是硬核还是营销?
· 终于写完轮子一部分:tcp代理 了,记录一下
· 【杭电多校比赛记录】2025“钉耙编程”中国大学生算法设计春季联赛(1)
点击右上角即可分享
微信分享提示