两数之和

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

你可以假设每种输入只会对应一个答案。但是,数组中同一个元素不能使用两遍。

示例:

给定 nums = [2, 7, 11, 15], target = 9

因为 nums[0] + nums[1] = 2 + 7 = 9
所以返回 [0, 1]

先看数组中是否存在余数,在看数组下标是否相同

class Solution {

    /**

     * @param Integer[] $nums

     * @param Integer $target

     * @return Integer[]

     */

    function twoSum($nums, $target) {

        foreach ($nums as $k=> $v) {

            $n=$target-$nums[$k];

            if(in_array($n,$nums)){

                $k1 = array_search($n,$nums);

                if($k == $k1) continue;

                return [$k,$k1];

            }

        }

    }

}
本作品采用《CC 协议》,转载必须注明作者和本文链接
《L01 基础入门》
我们将带你从零开发一个项目并部署到线上,本课程教授 Web 开发中专业、实用的技能,如 Git 工作流、Laravel Mix 前端工作流等。
《L05 电商实战》
从零开发一个电商项目,功能包括电商后台、商品 & SKU 管理、购物车、订单管理、支付宝支付、微信支付、订单退款流程、优惠券等
讨论数量: 4
AloneUtopia

这好像是力扣上的题吧。。你这时间复杂度太高了, 外边遍历 里面 in_array array_search....

3年前 评论
keon (楼主) 3年前
AloneUtopia (作者) 3年前
       foreach ($nums as $k=> $v) {

            $n=$target-$nums[$k];
            if($k1 = array_search($n,$nums)) {
                return [$k,$k1];
            }
        }

        return null;
3年前 评论
keon (楼主) 3年前
AloneUtopia
function twoSum($nums, $target) {
        $count=count($nums);
        $flipNums=array_flip($nums);
        for($i=0;$i<$count;$i++){
            $find=$target-$nums[$i];
            if(isset($flipNums[$find]) && $i!==$flipNums[$find]){
                return [$i,$flipNums[$find]];
            }
        }
        return [0,0];
    }
function twoSum($nums, $target) {
        $found = [];

        foreach ($nums as $key => $val) {
            $diff = $target - $val;

            if (!isset($found[$diff])) {
                $found[$val] = $key;
                continue;
            }

            return [$found[$diff], $key];
        }
    }
3年前 评论
win 3年前

可以看我的系列文章哦~

3年前 评论

讨论应以学习和精进为目的。请勿发布不友善或者负能量的内容,与人为善,比聪明更重要!
未填写
文章
1
粉丝
0
喜欢
0
收藏
0
排名:2485
访问:472
私信
所有博文
社区赞助商