当前位置:首页 > PHP > 正文内容

letcode两数之和php版本

高老师5年前 (2020-11-07)PHP1178

先看看题目:

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

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

示例:

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

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

(1).暴力枚举.我第一次做这道题只能想到这个,文科生有点丢人了。两个大循环,每次循环都用目标值去减去当前值,如果结果的值在这个数组中,并且不是当前值则返回当前值的位置和结果值的位置。

class Solution
{
    /**
     * @param Integer[] $nums
     * @param Integer $target
     * @return Integer[]
     */
    function twoSum($nums, $target)
    {
        foreach ($nums as $key => $value)
        {
            $temp = $target - $value;
            foreach ($nums as $key2 => $value2)
            {
                if ($value2 == $temp && $key2 != $key)
                {
                    return [$key, $key2];
                }
            }
        }
    }
}

(2).哈希表. 建立一个哈希表,key保存每个元素的值,value保存每个元素原来的key.每次循环时判断哈希表是否存在一个(目标值-当前元素)的值,存在则返回当前元素的key和哈希表中的位置。我起初认为这样是不正确的,因为上面要求返回的是[0,1],但是我们这样来做结果是[1,0],不过我看了下letcode的题解,这样也是正确的。

class Solution
{
    /**
     * @param Integer[] $nums
     * @param Integer $target
     * @return Integer[]
     */
    function twoSum($nums, $target)
    {
        $hash = [];
        foreach ($nums as $key => $value)
        {
            $temp = $target - $value;
            if (isset($hash[$temp]))
            {
                return [$key, $hash[$temp]];
            }
            $hash[$value] = $key;
        }
    }
}

很显然hash来处理更快

扫描二维码推送至手机访问。

版权声明:本文由高久峰个人博客发布,如需转载请注明出处。

本文链接:https://blog.20230611.cn/post/188.html

分享给朋友:

“letcode两数之和php版本” 的相关文章

全方位认识PHP的SESSION

全方位认识PHP的SESSION

【一】.介绍session由于HTTP是无状态的请求,创建一个会话需要保持必须需要身份标识。当用户第一次访问,PHP会为用户创建一个唯一的sessionid,并将sessionid通过cookie发送给浏览器,并在服务器的临时文件创建一个以sessionid为名的文件用来保存这个sessionid保...

redis订阅和发布,redis消息订阅与发布, phpredis订阅和发布

redis订阅和发布,redis消息订阅与发布, phpredis订阅和发布

Redis提供了发布订阅功能,可以用于消息的传输,Redis的发布订阅机制包括三个部分,发布者(publisher),订阅者(subscriber)和频道(channel)。 发布者和订阅者都是Redis客户端,Channel则为Redis服务器端,发布者将消息发送到某个的频道,订阅了这个...

cookie跨域,cookie p3p跨域

cookie跨域,cookie p3p跨域

最近在公司开发一个新的项目假设项目域名是a.com,需要接入b.com的单点登陆系统。(1).首先我们会在a.com的登陆页面用iframe引入b.com来显示登陆界面,实际上登陆验证操作都是在b.com上面(2).当b.com验证通过,会在前端ajax请求a.com的回调地址,这个回调地址目的就是...

swoole中的worker_num和task_worker_num

swoole中的worker_num和task_worker_num

(1)swoole启动的主进程是master进程负责全局管理,然后master进程会再fork一个manager进程。(2)manager进程开始统一管理进程创建回收管理。(3)manager进程根据设置的worker_num和task_worker_num来创建work进程和task进程因此启动s...

php finally使用

php finally使用

<?php /**  * @throws Exception  */ function curl() {     throw  new \Exception('err...

 php命令行中文乱码,php cli中文乱码

php命令行中文乱码,php cli中文乱码

<?php //如果支持exec函数,可以使用的方式 exec('chcp 65001'); //如果exec函数因安全问题禁用,可以使用的方式 pclose(popen('chcp 65001', 'r'));...