Leetcode基础刷题之PHP解析(7. Reverse Integer)

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

2 0 1 9 -6-20   期四  

Leetcode基础刷题 PHP 解析(103. Binary Tree Zigzag Level Order Traversal)

Leetcode基础刷题之PHP解析(7. Reverse Integer)

给定一个32位整形,让我们反转它的整数,也就是说如果是负数,只是把负数后的数字进行反转,依然是负数。

这里唯一要注意的是note下说如果给定我们的环境只能存储32位带符号的整数范围,溢出的话,直接返回0.

/**
     * @param Integer $x
     * @return Integer
     */
    function reverse($x) {
        $true=1;
        if($x<0) $true= -1;
        $x *= $true;
        $x=strrev($x);
        $x = intval($x) * $true;
        if ($x >= pow(2, 31) - 1) return 0;
        if ($x <= pow(2, 31) * -1) return 0;
        return $x;
    }

看到一哥们的解,你们感受一下

/**
     * @param Integer $x
     * @return Integer
     */
    function reverse($x) {
 
          if($x == 0) return $x;
        $num = abs($x);
        $sign = $x<0 ? -1 : 1;
        $digits = array();
        while($num>0){
            array_push($digits, $num%10);
            $num = floor($num/10);
        }
        $reversedNum = 0;
        $factor = 1;
        for($i = count($digits)-1; $i>=0; --$i) {
            $reversedNum += $digits[$i]*$factor;
            $factor*= 10;
        }
        if(($sign>0 && $reversedNum > 2147483648-1) || ($sign<0 && $reversedNum >2147483648))
            return 0;
        return $sign*$reversedNum;
        
    }

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


以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持 码农网

查看所有标签

猜你喜欢:

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

Effective Ruby:改善Ruby程序的48条建议

Effective Ruby:改善Ruby程序的48条建议

Peter J. Jones / 杨政权、秦五一、孟樊超 / 机械工业出版社 / 2016-1 / 49

如果你是经验丰富的Rub程序员,本书能帮助你发挥Ruby的全部力量来编写更稳健、高效、可维护和易执行的代码。Peter J.Jones凭借其近十年的Ruby开发经验,总结出48条Ruby的最佳实践、专家建议和捷径,并辅以可执行的代码实例。 Jones在Ruby开发的每个主要领域都给出了实用的建议,从模块、内存到元编程。他对鲜为人知的Ruby方言、怪癖、误区和强力影响代码行为与性能的复杂性的揭......一起来看看 《Effective Ruby:改善Ruby程序的48条建议》 这本书的介绍吧!

在线进制转换器
在线进制转换器

各进制数互转换器

XML 在线格式化
XML 在线格式化

在线 XML 格式化压缩工具

Markdown 在线编辑器
Markdown 在线编辑器

Markdown 在线编辑器