PHP의 피보나치 수열을 위한 N 알고리즘

머리말
얼마 전 피보나치 수의 계산을 최적화하는 기존의 재귀적 방법을 접했지만 제때에 좋은 방법이 생각나지 않아 나중에 관련 정보를 찾아보며 많이 정리한 계산 솔루션이 있어서 모두와 공유하고 소통하며 배웁니다.
추천: "PHP 비디오 튜토리얼"
피보나치 수열이란 무엇입니까
황금분할 수열이라고도 알려진 피보나치 수열은 수학자 레오나르도 피보나치 레오나르도 피보나치가 토끼 번식의 예를 들어 소개했기 때문에, 그래서 "토끼 수열"이라고도 하는데, 1, 1, 2, 3, 5, 8, 13, 21, 34,… … 수학적으로 피보나치 수열은 다음과 같이 재귀적으로 정의됩니다. F (1)=1, F(2)=1, F(n)=F(n - 1)+F(n - 2) (n ≥ 3, n ∈ N*).
이제 피보나치 수
를 알았으니 다양한 방법을 사용하여 N번째 피보나치 수를 계산하고 구해 보겠습니다. 斐波那契数
,那么下面我们就用多种不同的方法来计算获取第N位斐波那契数。
普通递归
这种方法是最常规的,直接根据定义F(n)=F(n - 1)+F(n - 2)
递归计算即可,但是性能是最低的。
/** * 普通递归 * @param int $n * @return int */function fib($n = 1){ // 低位处理 if ($n < 3) { return 1; } // 递归计算前两位 return fib($n - 1) + fib($n - 2); }
递归优化
从上面的递归方法可以看到,进行了很多的重复计算,性能极差,如果N越大,计算的次数太可怕了,那么,既然因为重复计算影响了性能,那么优化就从减少重复计算入手,即把之前计算的存储起来,这样就避免了过多的重复计算,优化了递归算法。
/** * 递归优化 * @param int $n * @param int $a * @param int $b * @return int */function fib_2($n = 1, $a = 1, $b = 1){ if ($n > 2) { // 存储前一位,优化递归计算 return fib_2($n - 1, $a + $b, $a); } return $a; }
记忆化自底向上
自底向上通过迭代计算斐波那契数的子问题并存储已计算的值,通过已计算的值进行计算。使用for
循环,减少递归带来的重复计算问题。
/** * 记忆化自底向上 * @param int $n * @return int */function fib_3($n = 1){ $list = []; for ($i = 0; $i <= $n; $i++) { // 从低到高位数,依次存入数组中 if ($i < 2) { $list[] = $i; } else { $list[] = $list[$i - 1] + $list[$i - 2]; } } // 返回最后一个数,即第N个数 return $list[$n]; }
自底向上进行迭代
最低位初始化赋值,使用for
从低位到高位迭代计算,从而得到第N个数。
/** * 自底向上进行迭代 * @param int $n * @return int */function fib_4($n = 1){ // 低位处理 if ($n <= 0) { return 0; } if ($n < 3) { return 1; } $a = 0; $b = 1; // 循环计算 for ($i = 2; $i < $n; $i++) { $b = $a + $b; $a = $b - $a; } return $b; }
公式法
通过了解斐波那契序列和黄金分割比之间的关系,使用黄金分割率计算第N
일반 재귀
이 방법은F(n)=F(n - 1)+F(n - 2)
정의에 따라 재귀적으로 계산할 수 있습니다. 그러나 성능은 미미합니다. /** * 公式法 * @param int $n * @return int */function fib_5($n = 1){ // 黄金分割比 $radio = (1 + sqrt(5)) / 2; // 斐波那契序列和黄金分割比之间的关系计算 $num = intval(round(pow($radio, $n) / sqrt(5))); return $num; }

/** * 无敌欠揍法 * @param int $n * @return int */function fib_6($n = 1){ // 列举了30个数 $list = [1, 1, 2, 3, 5, 8, 13, 21, 34, 55, 89, 144, 233, 377, 610, 987, 1597, 2584, 4181, 6765, 10946, 17711, 28657, 46368, 75025, 121393, 196418, 317811, 514229, 832040, 1346269]; return $list[$n]; }
Memory Bottom-up
Bottom-up은 피보나치 수열의 하위 문제를 반복적으로 계산하여 계산된 값을 저장하고, 계산된 값을 기반으로 계산을 수행합니다. 재귀로 인해 발생하는 이중 계산 문제를 줄이려면 for
루프를 사용하세요.
아래에서 위로 반복
for
를 사용하여 낮은 비트에서 높은 비트까지 반복 계산하여 N번째 숫자를 얻습니다. 🎜rrreee🎜🎜공식 방법🎜🎜🎜피보나치 수열과 황금비의 관계를 이해함으로써 황금비를 이용하여 N
번째 피보나치 수를 계산합니다. 🎜rrreee🎜🎜무적의 방법🎜🎜🎜이 방법에 대해서는 많이 말하지 않겠습니다. 모두가 알고 있지만 쉽게 시도하지 마세요...🎜🎜🎜🎜🎜🎜rrreee🎜🎜드디어🎜🎜🎜그래요, 나 여러 가지 해결 방법을 대략적으로 작성해 놓았습니다. 잘못된 부분이 있으면 지적해 주시면 수정하겠습니다. 다른 계산 방법이 있으면 공유해 함께 소통하고 배워 보세요. 🎜🎜🎜🎜위 내용은 PHP의 피보나치 수열을 위한 N 알고리즘의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

핫 AI 도구

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

Video Face Swap
완전히 무료인 AI 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

인기 기사

뜨거운 도구

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전
중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

드림위버 CS6
시각적 웹 개발 도구

SublimeText3 Mac 버전
신 수준의 코드 편집 소프트웨어(SublimeText3)

C++에서 피보나치 수열 알고리즘을 사용하는 방법 피보나치 수열은 매우 고전적인 수열이며 각 숫자는 이전 두 숫자의 합이라고 정의됩니다. 컴퓨터 과학에서 C++ 프로그래밍 언어를 사용하여 피보나치 수열 알고리즘을 구현하는 것은 기본적이고 중요한 기술입니다. 이 기사에서는 C++를 사용하여 피보나치 수열 알고리즘을 작성하는 방법을 소개하고 구체적인 코드 예제를 제공합니다. 1. 재귀적 방법 재귀는 피보나치 수열 알고리즘의 일반적인 방법입니다. C++에서는 재귀를 사용하여 피보나치 수열 알고리즘을 간결하게 구현할 수 있습니다. 아래에

PHP 프로그래밍에서 알고리즘은 필수적인 부분입니다. 공통 알고리즘을 익히면 코드 효율성이 향상될 뿐만 아니라 후속 프로그램 설계에도 도움이 됩니다. 다음은 PHP 프로그래밍의 일반적인 알고리즘입니다. 정렬 알고리즘 정렬 알고리즘은 특정 규칙에 따라 일련의 데이터를 정렬된 순서로 배열하는 것을 의미합니다. PHP 프로그래밍에서 일반적으로 사용되는 정렬 알고리즘에는 버블 정렬, 삽입 정렬, 선택 정렬, 빠른 정렬 등이 있습니다. 그 중 퀵 정렬은 시간 복잡도가 가장 낮은 정렬 알고리즘으로, 대규모 데이터 처리에 적합하다. 검색 알고리즘 검색 알고리즘

Python에서 피보나치 수열을 해결하는 알고리즘을 작성하는 방법은 무엇입니까? 피보나치 수열은 다음과 같이 정의되는 고전적인 수열입니다. 첫 번째와 두 번째 숫자는 모두 1이고 세 번째 숫자부터 시작하여 각 숫자는 이전 두 숫자의 합입니다. 즉, 1,1,2,3,5,8,13,21,34,... Python에서는 루프나 재귀를 사용하여 피보나치 수열을 푸는 알고리즘을 작성할 수 있습니다. 이 두 가지 방법의 구체적인 구현은 아래에 소개됩니다. 방법 1: 루프 사용루프 사용

PHP는 다양한 데이터 유형과 알고리즘을 지원하는 매우 널리 사용되는 프로그래밍 언어이며, 배열 정렬 및 검색 알고리즘은 기본적이고 중요한 부분입니다. 이 기사에서는 PHP에서 일반적으로 사용되는 배열 정렬 및 검색 알고리즘과 해당 애플리케이션 시나리오 및 효율성 분석을 소개합니다. 1. 배열 정렬 PHP는 버블 정렬, 삽입 정렬, 선택 정렬, 퀵 정렬, 병합 정렬 등 다양한 배열 정렬 방법을 제공합니다. 다음은 일반적으로 사용되는 여러 알고리즘에 대한 소개 및 샘플 코드입니다. 버블 정렬(BubbleSort)

피보나치 수열은 처음 두 숫자를 더하여 얻은 일련의 숫자입니다. 피보나치 수열은 두 개의 숫자 f0과 f1로 시작됩니다. fo와 f1의 초기값은 0, 1 또는 1, 1일 수 있습니다. 피보나치 수열은 다음 조건을 만족합니다. fn=fn-1+fn-2 알고리즘은 피보나치 수열의 알고리즘을 말합니다. STARTStep1:Readintegervariablea,b,catruntimeStep2:Initializea=0andb=0Step3:Computec=a+bStep4:PrintcStep5:Seta=b,b=cStep6:Repeat3to5fornt

PHP는 웹 개발에 널리 사용되는 스크립팅 언어이며 동적 웹사이트 구축에 있어 점점 더 발전하고 있습니다. 웹 개발에서 데이터 구조와 알고리즘은 다른 프로그래밍 범주만큼 중요하며, 프로그램 실행 효율성에 미치는 영향은 특히 중요합니다. 특히 대용량 데이터 저장 및 처리나 높은 프로그램 성능 요구 사항이 포함된 시나리오에서 데이터 구조와 알고리즘은 무시할 수 없는 부분이 되었습니다. 이 글에서는 주로 PHP에서 일반적으로 사용되는 데이터 구조와 알고리즘을 소개합니다. 1. 데이터 구조 배열 PHP 배열은 매우 일반적입니다.

인터넷의 대중화와 애플리케이션의 지속적인 확장으로 인해 프로그래밍 언어의 개발이 점점 더 중요해지고 있습니다. 매우 인기 있는 프로그래밍 언어인 PHP도 지속적으로 발전하고 있습니다. PHP로 프로그래밍하는 과정에서 PHP 개발자는 일부 지식을 표현하고 자동으로 알고리즘을 생성해야 할 필요성에 직면할 수 있습니다. 그렇다면 PHP에서 지식을 표현하고 알고리즘을 자동으로 생성하는 방법은 무엇입니까? 이 기사에서는 이에 대해 아래에서 논의할 것입니다. 1. 지식 표현 지식 표현은 인공지능 분야에서 매우 중요한 이슈이다. 알다

두뇌 매핑 기능에서 PHP와 Vue의 핵심 알고리즘에 대한 심층적인 이해 소개: 현대 인터넷 시대에 우리는 정보를 정리하고 관리하는 데 도움을 주기 위해 다양한 애플리케이션을 자주 사용합니다. 뇌 매핑은 복잡한 사고 과정을 그래픽으로 표시할 수 있는 정보를 구성하는 일반적이고 실용적인 방법입니다. 이번 글에서는 두뇌 매핑 기능에서 PHP와 Vue의 핵심 알고리즘에 초점을 맞추고 코드 예제를 제공하겠습니다. 1. 마인드맵의 특징 마인드맵은 중심주제를 핵심으로 삼아 그 주제와 관련된 정보를 트리구조로 표시하는 일종의 뇌지도이다.
