通过循环检查数字是否是斐波纳契数

时间:2016-02-29 00:55:47

标签: php html fibonacci

所以我试图在这里完成的任务是将用户输入数字与斐波纳契数列进行比较,如果是斐波那契数字,程序将回显为真,如果不是,它将回显为假。

有人可以告诉我哪里出错了?

这是我的第一个档案:

<?php
function print_fibonacci($n){

    $first = 0;
    $second = 1;

    echo "Fibonacci Series: \n";

    echo $first.' '.$second.' ';

    for($i=2;$i<$n;$i++){

        $third = $first + $second;

        echo $third.' ';

        $first = $second;
        $second = $third;

    }
}


/* Function call to print Fibonacci series upto 6 numbers. */

print_fibonacci(16);

 ?>

<form method="POST" action="fibonacci3.php"><br>
<label>Input a number to check if it is fibonacci or not.</label><br>
<input name="fib" type="text" placeholder="#" /><br>
<input type="submit" value="OK!" />
</form>

这将输出斐波纳契序列,直到第16个斐波纳契数,然后是一个允许用户输入数字的表格。

下一个文件是表格中引用的fibonacci3.php。

<?php

include "fibonacci2.php";

$n = $_POST["fib"];

function fibonacci($n) {

    //0, 1, 1, 2, 3, 5, 8, 13, 21

    /*this is an error condition
    returning -1 is arbitrary - we could
    return anything we want for this
    error condition:
    */
    if((int)$n <0){
        return -1;
        echo "False";
    }

    if ((int)$n == 0){
        return 0;
        echo "0";
    }

    if((int)$n == 1 || $n == 2){
        return 1;
    }

    $int1 = 1;
    $int2 = 1;

    $fib = 0;


    for($i=1; $i<=$n-2; $i++ )
    {
        $fib = $int1 + $int2;
        //swap the values out:
        $int2 = $int1;
        $int1 = $fib;
    }

    if ($fib = $int1 + $int2 && $n == $fib){
        echo "True!";
    } else {
        echo "False!";
    }

    return $fib;

}

fibonacci((int)$n);
?>

我认为这可能是正确的,但在用户输入数字时却没有输出任何内容。

1 个答案:

答案 0 :(得分:0)

@add_lines_num_start
#=> [[1830, 1], [1859, 1]]
@add_lines_num_start.include? 1830
#=> false
@add_lines_num_start.first.include? 1830
#=> true