목차
앞서 언급했듯이 재귀는 큰 문제를 작은 문제로 나누는 솔루션입니다. 일반적으로 재귀를 함수 자체에 대한 호출이라고 합니다. 이렇게 말하는 것이 이상하게 들릴 수도 있지만 실제로 재귀에서 함수는 자신을 호출해야 합니다.
5*4*3*2*1입니다. " >예를 들어 수학에서 우리 모두는 "계승"이라는 개념을 알고 있습니다. 예를 들어 5의 계승은 5*4*3*2*1입니다.
递归算法的特性
n의 계승을 찾는 규칙, 즉 n! = n * (n -1) !
백엔드 개발 PHP 튜토리얼 PHP 데이터 구조를 기반으로 한 재귀

PHP 데이터 구조를 기반으로 한 재귀

Jul 07, 2018 pm 03:29 PM
재귀 재귀 호출

이 기사는 주로 PHP 데이터 구조를 기반으로 재귀를 소개합니다. 이는 특정 참조 값을 가지고 있습니다. 이제 도움이 필요한 친구들이 참조할 수 있습니다.

앞서 언급했듯이 재귀는 큰 문제를 작은 문제로 나누는 솔루션입니다. 일반적으로 재귀를 함수 자체에 대한 호출이라고 합니다. 이렇게 말하는 것이 이상하게 들릴 수도 있지만 실제로 재귀에서 함수는 자신을 호출해야 합니다.

밤나무

예를 들어 수학에서 우리 모두는 "계승"이라는 개념을 알고 있습니다. 예를 들어 5의 계승은 5*4*3*2*1입니다.

5*4*3*2*1

  • 5!= 5 * 4!

  • 4!= 4 * 3!

  • 3!= 3 * 2!

  • 2!= 2 * 1!

  • 1!= 1 * 0!

  • 0!= 1

我们可以总结出求n的阶乘的规律,即 n! = n * (n -1) !

这就体现了递归。你可以从中发现,我们把求5的阶乘一步一步转化成了另外一个个的小问题。

递归算法的特性

  • 每一个递归调用都必须基于一个小的子问题。例如5的阶乘就是5乘4的阶乘。

  • 递归必须有一个Base case。例如阶乘的Base case就是0,当条件是0的时候,就停止递归。

  • 递归中避免循环调用,否则最后计算机会显示栈溢出的错误。

function factorial(int $n): int
{
    if ($n = 0) {
        return 1;
    }
    
    return $n * factorial($n - 1);
}
로그인 후 복사

看上面的代码,我们可以看到对于阶乘问题的解决方案我们有一个基础的条件就是当n为0的时候,我们返回1。如果不符合这个条件,我们返回nfactorial(n)

5! = 5 * 4!

PHP 데이터 구조를 기반으로 한 재귀

4! = 4 * 3!

3! = 3 * 2!

2! = 2 * 1!

PHP 데이터 구조를 기반으로 한 재귀

1! = 1 * 0!

0! = 1

PHP 데이터 구조를 기반으로 한 재귀

n의 계승을 찾는 규칙, 즉 n! = n * (n -1) !

    이것은 재귀를 반영합니다. 여기에서 우리는 5의 계승을 또 다른 작은 문제로 단계별로 변형했다는 것을 알 수 있습니다.
  • 재귀 알고리즘의 특성

모든 재귀 호출은 작은 하위 문제를 기반으로 해야 합니다. 예를 들어, 5의 계승은 5 곱하기 4의 계승입니다.

  • 재귀에는 기본 사례가 있어야 합니다. 예를 들어 계승의 기본 사례는 0입니다. 조건이 0이면 재귀가 중지됩니다.

재귀 중에 루프 호출을 피하세요. 그렇지 않으면 컴퓨터에 결국 스택 오버플로 오류가 표시됩니다.

  • function factorial(int $n): int
    {
        $result = 1;
        
        for ($i = $n; $i > 0; $i--) {
            $result*= $n;
        }
        
        return $result;
    }
    로그인 후 복사

    위의 코드를 보면 계승 문제를 풀기 위한 기본 조건이 있다는 것을 알 수 있습니다. 즉, n이 0일 때 1을 반환한다는 것입니다. 이 조건이 충족되지 않으면 첫 번째와 세 번째 재귀 속성을 준수하는 factorial(n)을 곱한 n을 반환합니다. 각 재귀 호출을 더 큰 문제의 더 작은 하위 문제로 나누기 때문에 반복 호출을 방지합니다. 위의 알고리즘 아이디어는 다음과 같이 표현할 수 있습니다.

  • Recursion Vs Iteration

반복 방법을 사용하여 위의 재귀 코드를 구현할 수도 있습니다
    function fibonacci($n)
    {
        if ($n == 0) {
            return 0;
        }
        
        if ($n == 1) {
            return 1;
        }
        
        return fibonacci($n - 1) + fibonacci($ - 2);
    }
    로그인 후 복사
  • 문제가 반복을 사용하여 쉽게 해결될 수 있다면 왜 재귀를 사용해야 할까요?

    재귀는 더 복잡한 문제를 처리하는 데 사용됩니다. 단순히 반복을 사용하여 모든 문제를 해결할 수 있는 것은 아닙니다. 재귀는 함수 호출을 사용하여 호출 스택을 관리하므로 재귀는 반복보다 더 많은 시간과 메모리를 사용합니다. 또한 반복에서는 각 단계에서 결과를 얻지만 재귀에서는 결과를 얻기 전에 기본 사례 실행이 끝날 때까지 기다려야 합니다. 위의 예를 보면 재귀 알고리즘에서는 결과를 저장할 변수나 선언이 없는 반면, 반복 알고리즘에서는 $result를 사용하여 매번 반환된 결과를 저장합니다.
피보나치 수열

수학에서 피보나치 수열은 특별한 정수 수열입니다. 수열의 각 숫자는 다른 두 숫자의 합으로 생성됩니다. 규칙은 다음과 같습니다:
  • function gcd(int $a, int $b)
    {
        if ($b == 0) {
            return $a;
        }
        
        return gcd($b, $a % $b);
    }
    로그인 후 복사
    최대 공약수

    재귀 알고리즘을 사용하는 또 다른 일반적인 문제는 두 숫자의 최대 공약수를 찾는 것입니다.

    PHP 데이터 구조를 기반으로 한 재귀

    rrreee

    재귀 유형

    선형 재귀

    🎜🎜🎜각 재귀 호출에서 함수는 자신을 한 번만 호출하는데, 이를 선형 재귀라고 합니다. 🎜🎜🎜🎜Biary Recursion🎜🎜🎜🎜이진 재귀에서는 함수에 대한 각 재귀 호출이 자신을 두 번 호출합니다. 피보나치 수열을 푸는 알고리즘은 이진 재귀이며, 그 밖에 이진 검색, 분할 정복 알고리즘, 병합 정렬 등도 이진 재귀를 사용합니다. 🎜🎜🎜🎜꼬리 재귀🎜🎜🎜🎜재귀가 대기 작업 없이 반환되는 경우를 꼬리 재귀라고 합니다. 피보나치 알고리즘에서는 반환값에 이전 재귀의 반환값을 곱해야 하기 때문에 꼬리 재귀가 아니며, 최대공약수를 푸는 알고리즘은 꼬리 재귀이다. 꼬리 재귀는 선형 재귀의 한 형태입니다. 🎜🎜🎜🎜상호 재귀🎜🎜🎜🎜예를 들어 각 재귀 호출에서 A()는 B()를 호출하고 B()는 A()를 호출합니다. 🎜🎜🎜🎜중첩 재귀🎜🎜🎜🎜재귀 함수가 자신을 매개변수로 재귀적으로 호출하는 것을 중첩 재귀라고 합니다. 일반적인 예는 Ackerman 함수입니다. 아래 표현식을 참조하세요. 🎜🎜🎜🎜🎜마지막 줄을 보시면 두 번째 매개변수가 재귀함수 그 자체임을 알 수 있습니다. 🎜🎜다음 섹션🎜🎜다음 기사에서는 재귀를 사용하여 N 수준 분류 구축, 중첩 주석 구축, 디렉터리 파일 탐색 등과 같은 실제 개발에서 직면하는 몇 가지 문제를 해결합니다. 🎜

    위 내용은 이 글의 전체 내용입니다. 모든 분들의 학습에 도움이 되길 바랍니다. 더 많은 관련 내용은 PHP 중국어 홈페이지를 참고해주세요!

    관련 권장 사항:

    PHP에서 클라이언트의 실제 IP 주소를 얻는 방법

    PHP에서 Elasticsearch를 사용하는 방법

    위 내용은 PHP 데이터 구조를 기반으로 한 재귀의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

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

AI Clothes Remover

AI Clothes Remover

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

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

AI Hentai Generator

AI Hentai Generator

AI Hentai를 무료로 생성하십시오.

뜨거운 도구

메모장++7.3.1

메모장++7.3.1

사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전

SublimeText3 중국어 버전

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

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

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

C++ 함수의 재귀 구현: 재귀 깊이에 제한이 있나요? C++ 함수의 재귀 구현: 재귀 깊이에 제한이 있나요? Apr 23, 2024 am 09:30 AM

C++ 함수의 재귀 깊이에는 제한이 있습니다. 이 제한을 초과하면 스택 오버플로 오류가 발생합니다. 제한 값은 시스템과 컴파일러에 따라 다르지만 일반적으로 1,000에서 10,000 사이입니다. 솔루션에는 다음이 포함됩니다. 1. 테일 재귀 최적화, 2. 테일 호출, 3. 반복 구현.

C++ 람다 표현식은 재귀를 지원합니까? C++ 람다 표현식은 재귀를 지원합니까? Apr 17, 2024 pm 09:06 PM

예, C++ Lambda 표현식은 std::function을 사용하여 재귀를 지원할 수 있습니다. std::function을 사용하여 Lambda 표현식에 대한 참조를 캡처합니다. 캡처된 참조를 사용하면 Lambda 표현식이 자신을 재귀적으로 호출할 수 있습니다.

Java에서 부분 문자열의 발생 횟수를 재귀적으로 계산합니다. Java에서 부분 문자열의 발생 횟수를 재귀적으로 계산합니다. Sep 17, 2023 pm 07:49 PM

두 개의 문자열 str_1과 str_2가 주어졌습니다. 목표는 재귀 프로시저를 사용하여 문자열 str1에서 하위 문자열 str2의 발생 횟수를 계산하는 것입니다. 재귀 함수는 정의 내에서 자신을 호출하는 함수입니다. str1이 "Iknowthatyouknowthatiknow"이고 str2가 "know"인 경우 발생 횟수는 -3입니다. 예를 들어 str1="TPisTPareTPamTP", str2="TP"를 입력하면 Countofoccurrencesofasubstringrecursi가 출력됩니다.

C++에서 배열의 최소 및 최대 요소를 찾는 재귀 프로그램 C++에서 배열의 최소 및 최대 요소를 찾는 재귀 프로그램 Aug 31, 2023 pm 07:37 PM

정수 배열 Arr[]을 입력으로 사용합니다. 목표는 재귀적 방법을 사용하여 배열에서 가장 큰 요소와 가장 작은 요소를 찾는 것입니다. 재귀를 사용하고 있으므로 길이 = 1에 도달할 때까지 전체 배열을 반복한 다음 기본 사례를 구성하는 A[0]을 반환합니다. 그렇지 않은 경우 현재 요소는 현재 최소값 또는 최대값과 비교되고 해당 값은 후속 요소에 대해 반복적으로 업데이트됩니다. 이에 대한 다양한 입력 및 출력 시나리오를 살펴보겠습니다. −Input −Arr={12,67,99,76,32} Output −배열의 최대값: 99 설명 &mi

C++ 함수의 재귀적 구현: 재귀적 알고리즘과 비재귀적 알고리즘의 비교 분석? C++ 함수의 재귀적 구현: 재귀적 알고리즘과 비재귀적 알고리즘의 비교 분석? Apr 22, 2024 pm 03:18 PM

재귀 알고리즘은 함수 자체 호출을 통해 구조화된 문제를 해결하지만 간단하고 이해하기 쉽다는 장점이 있지만 효율성이 떨어지고 스택 오버플로가 발생할 수 있다는 단점이 있습니다. 스택 데이터 구조의 장점은 더 효율적이고 스택 오버플로를 방지한다는 것입니다. 단점은 코드가 더 복잡할 수 있다는 것입니다. 재귀적 또는 비재귀적 선택은 문제와 구현의 특정 제약 조건에 따라 달라집니다.

C++ 함수 재귀에 대한 자세한 설명: 문자열 처리에 재귀 적용 C++ 함수 재귀에 대한 자세한 설명: 문자열 처리에 재귀 적용 Apr 30, 2024 am 10:30 AM

재귀 함수는 문자열 처리 문제를 해결하기 위해 자신을 반복적으로 호출하는 기술입니다. 무한 재귀를 방지하기 위해서는 종료 조건이 필요합니다. 재귀는 문자열 반전 및 회문 검사와 같은 작업에 널리 사용됩니다.

C++ 재귀에 대한 초보자 가이드: 기초 구축 및 직관 개발 C++ 재귀에 대한 초보자 가이드: 기초 구축 및 직관 개발 May 01, 2024 pm 05:36 PM

재귀는 문제를 해결하기 위해 함수가 자신을 호출할 수 있도록 하는 강력한 기술입니다. C++에서 재귀 함수는 두 가지 핵심 요소, 즉 기본 사례(재귀 중지 시기를 결정함)와 재귀 호출(문제를 여러 단계로 나누는 경우)로 구성됩니다. 더 작은 하위 문제). 기초를 이해하고 계승 계산, 피보나치 수열, 이진 트리 순회 등의 실제 예제를 연습함으로써 재귀적 직관을 구축하고 자신 있게 코드에서 사용할 수 있습니다.

Linux에서 재귀 'ls'를 사용하는 방법 Linux에서 재귀 'ls'를 사용하는 방법 Mar 20, 2024 am 10:03 AM

Linux 시스템에서 "ls" 명령은 현재 디렉터리에 있는 파일과 폴더에 대한 간략한 개요를 제공하는 매우 유용한 도구입니다. "ls" 명령을 통해 파일, 폴더의 권한, 속성 등 중요한 정보를 빠르게 확인할 수 있습니다. "ls" 명령은 기본 명령이지만 다양한 하위 명령과 옵션을 결합하여 시스템 관리자와 사용자에게 중요한 도구가 될 수 있습니다. "ls" 명령과 다양한 옵션을 능숙하게 사용하면 파일 시스템을 보다 효율적으로 관리하고, 필요한 파일을 빠르게 찾고, 다양한 작업을 수행할 수 있습니다. 따라서 "ls" 명령은 현재 디렉토리 구조를 이해하는 데 도움이 될 뿐만 아니라 작업 효율성도 향상시킵니다. 예를 들어 Linux 시스템에서는 재귀 옵션과 함께 "ls"를 사용합니다.

See all articles