我不知道如何处理这个PHP代码


I dont know what to do with this PHP Code

下面的代码基本上有助于找出一个数字是否是Palindromic Number。虽然我用输出完成了我的执行,但我似乎可以处理我得到的所有"尖叫"和致命错误。我该如何处理这个问题。只是一个初学者,相信你可以用我可能能够理解的方式解释。

<?php
    for ($num = 1; $num <= 20; ++$num){
        $_array1 = str_split($num);
        //print_r($_array1);
        //echo "<br/>";
        $_array2 = array_reverse($_array1);
        //print_r($_array2);
        //echo "<br/>";
        $i = 0;
        $j = 0;
        while ($i < sizeof($_array1) && $j < sizeof($_array2)){
            if ($_array1[$i] == $_array2[$j]){
            ++$i;
            ++$j;
        }
        }
        if ($_array1[$i] == $_array2[$j]){
            echo "The number $num is a Palindrome Number";
        }
    }
?>

你得到元素的大小,即 1。但是,如果您的array只有一个元素,即 1 位数字的情况,则sizeof($_array) === 1 .这意味着您可以使用的最大可能索引是 0。您需要将代码更改为如下所示的内容:

<?php
    for ($num = 1; $num <= 20; ++$num){
        $_array1 = str_split($num);
        //print_r($_array1);
        //echo "<br/>";
        $_array2 = array_reverse($_array1);
        //print_r($_array2);
        //echo "<br/>";
        $i = 0;
        $j = 0;
        $different = false;
        while ((!$different) && ($i < sizeof($_array1))){
            if ($_array1[$i] == $_array2[$j]){
            ++$i;
            ++$j;
        } else {
            $different = true;
        }
        }
        if (!$different){
            echo "The number $num is a Palindrome Number";
        }
    }
?>

但是你正在反转array而不需要这样做,而且你正在循环不必要的时间。我提出这个function来确定数组是否是回文:

function isPalindrome($input) {
    $size = count($input);
    for ($index = 0; $index < $size / 2; $index++) {
        if ($input[$index] != $input[$size - $index - 1]) {
            return false;
        }
    }
    return true;
}

请注意,:

  • function假定array的键是数字
  • function使用单个array
  • array的大小存储在局部变量中,以免重复计算
  • 循环
  • 循环直到array的一半,因为由于!=算子的对称性质,超过该值是不必要的
  • 当找到第一个差异时,function返回false,以进一步优化检查
  • 如果没有差异,则function返回true,表示输入是回文