Leetcode PHP题解--D24 476. Number Complement

476. Number Complement

题目链接

476. Number Complement

题目分析

给定一个数字,将他转换成二进制后,将0和1对调过来,把对调后的二进制再转换成十进制。返回该数字即可。

思路

题目描述得已经很清楚了。

先用decbin转换成二进制,用str_replace把0和1对调过来。

要注意对调的时候,不能直接对调。需要先把0换成除1之外的其他字符,最后再把他替换过来。
因为str_replace会按顺序逐个替换。如果先把0替换成1,那么它在替换1的时候,会全替换成0。你就会得到全0的字符串。

替换完成之后,在用bindec转换成十进制即可。

最终代码

<?php
class Solution {
    function findComplement($num) {
        return bindec(str_replace([0,1,2],[2,0,1],decbin($num)));
    }
}

若觉得本文章对你有用,欢迎用爱发电资助。

点赞

发表评论

电子邮件地址不会被公开。 必填项已用*标注