Leetcode基础刷题之PHP解析(342,344,349)

栏目: PHP · 发布时间: 6年前

题外话: 最近身体越来越差了,提醒各位:注意休息注意休息注意休息!!!。

2 0 1 9 - 4 -23   期三    

今天还是3题。

一篇   Leetcode基础刷题之 PHP 解析(292,303,326)

Leetcode基础刷题之PHP解析(342,344,349)

给个整数,判断是否是4的幂次方。

题目让我们不使用递归或者循环,我们先使用循环或者递归实现一遍。

/**
     * @param Integer $num
     * @return Boolean
     */
    function isPowerOfFour($num) {
          while($num && $num%4==0){
              $num =floor($num/4);
          }
          return $num==1;    
    }

想不循环和递归,那就需要找到规律,只要是4的幂次方的数,那么把它减去一之后都可以被3整除,调整一下就压榨成一行了。

/**
     * @param Integer $num
     * @return Boolean
     */
    function isPowerOfFour($num) {
        return $num>0 && !($num & ($num-1)) && ($num-1)%3==0;
    }

Leetcode基础刷题之PHP解析(342,344,349)

写一个函数反转数组中的字符串,要求是只能原地换,也就是说只能使用O(1)的空间复杂度.

/**
     * @param String[] $s
     * @return NULL
     */
    function reverseString(&$s) {
        $j=count($s)-1;
        for($i=0;$i<$j;$i++){
            $temp=$s[$i];
            $s[$i]=$s[$j];
            $s[$j]=$temp;
            $j--;
        }; 
        return $s;
    }

Leetcode基础刷题之PHP解析(342,344,349)

从两个数组中找出他们的交集。我这里直接把数组元素多的那个进行循环,每次比较元素少的那个数组,只要不同的直接删掉,最后因为交集是要唯一的,所以再去重。可以利用二分查找进行优化。

/**
     * @param Integer[] $nums1
     * @param Integer[] $nums2
     * @return Integer[]
     */
    function intersection($nums1, $nums2) {
        $big=count($nums1)>count($nums2)?$nums1:$nums2;
        $small=count($nums1)>count($nums2)?$nums2:$nums1;
        for($i=0;$i<count($big);$i++){
            if(!in_array($small[$i],$big)){
                unset($small[$i]);
            }
        }
        return array_unique($small);
    }

Github整理地址:https://github.com/wuqinqiang/leetcode-php


以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,也希望大家多多支持 码农网

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

人人都在说谎

人人都在说谎

赛思·斯蒂芬斯--达维多维茨 / 胡晓姣、张晨、左润男 / 中信出版集团 / 2018-11 / 58

有多少人买了书真正看完了? 你朋友的酒量有他说的那么大吗? 父母是否暗自喜欢男孩儿多于女孩儿? 电影里暴力镜头增多会导致犯罪率升高吗? 种族歧视在现如今的美国还严重吗? 特朗普的胜利有征兆吗,什么促成他赢得了大选? …… 你知道问题的答案吗,直觉会怎样告诉你? 作者赛思·斯蒂芬斯--达维多维茨是一位前谷歌数据科学家和专栏作家。他的研究发现,世界充满了......一起来看看 《人人都在说谎》 这本书的介绍吧!

JSON 在线解析
JSON 在线解析

在线 JSON 格式化工具

RGB转16进制工具
RGB转16进制工具

RGB HEX 互转工具

XML、JSON 在线转换
XML、JSON 在线转换

在线XML、JSON转换工具