php 反转一个整数,LeetCode(PHP)之整数反转

题目:整数反转(Reverse Integer)

给出一个 32 位的有符号整数,你需要将这个整数中每位上的数字进行反转。

示例 1:

输入: 123

输出: 321

示例 2:

输入: -123

输出: -321

示例 3:

输入: 120

输出: 21

注意:

假设我们的环境只能存储得下 32 位的有符号整数,则其数值范围为 [−231, 231 − 1]。请根据这个假设,如果反转后整数溢出那么就返回 0。

解法一:

对传入数字进行取余操作每次弹出最后一位,推入变量ret中,每次再对ret进行推入时,要先判断推入后会不会溢出。

如果 ret =ret * 10 + pop 导致溢出,那么一定有ret >= xMax/10 或 ret <= xMin/10;

所以ret > xMax/10 或 ret < xMin/10,那么ret = ret* 10 + pop会溢出;

rev == xMax/10,那么只要pop > 7,ret = ret * 10 + pop会溢出;

rev == xMin/10,那么只要pop < -8,ret = ret * 10 + pop会溢出;

class Solution {

/**

* @param Integer $x

* @return Integer

*/

function reverse($x) {

$ret = 0;

$xMin = -pow(2, 31);

$xMax = pow(2, 31) - 1;

while($x != 0){

$pop = $x % 10; //pop为最后一位数字

if($ret < $xMin / 10 || ($ret == $xMin/10 && $pop < -8)){

return 0;

}

if($ret > $xMax / 10 || ($ret == $xMax/10 && $pop > 7)){

return 0;

}

$ret = $ret * 10 + $pop; //将最后一位推入到的第一位

$x = (int)($x / 10); //弹出最后一位数字

}

return $ret;

}

}

解法二:

转换成字符串,用php函数strrev反转字符串,然后判断是否溢出。

class Solution {

/**

* @param Integer $x

* @return Integer

*/

function reverse($x) {

if($x >= 0){

$ret = strrev((string)$x);

}else{

$ret = -strrev((string)abs($x));

}

if($ret > pow(2,31) - 1 || $ret < -pow(2,31)){

return 0;

}else{

return (int)$ret;

}

}

}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值