개인 재정 재귀의 맛 - 더미

재귀의 맛 - 더미

비디오: [반복반복] 영어회화 81 - 재귀대명사의 활용법 익히기 9편 2024

비디오: [반복반복] 영어회화 81 - 재귀대명사의 활용법 익히기 9편 2024
Anonim

재귀 는 프로그래밍에 대해 자주 듣는 크고 무서운 단어입니다. 특히 대학에서 가르치는 프로그래밍의 좌절스러운 종류입니다. 설명하는 것이 쉬운 개념이지만 재귀가 작동하는 방식을 이해하는 데는 정말 중요한 요소입니다. 대부분의 사람들은 그것을 받아들이고 계속 나아 간다. 여기 없어!

재귀 는 기본적으로 자체를 호출하는 함수의 프로세스입니다. 예:

void funct (int x) {funct (x);}

이 코드 덩어리에서는 재귀 함수의 끔찍한 예제를 보았지만 여기서는 설명의 목적을 제공한다. () 함수는 자신을 호출합니다. 그것은 재귀입니다. 이제이 예제에서 일어나는 일은 기본적으로 무한 루프이며, r , 스택 포인트라고하는 기술적 인 요소 덕분에 컴퓨터가 결국 중단됩니다. 그러나 그것은 단지 하나의 예일뿐입니다.

재귀가 작동하려면 루프와 마찬가지로 함수에 구제 조건이 있어야합니다. 따라서 재귀 함수에 전달 된 값이나 반환 값을 테스트해야합니다. 다음은 재귀 함수의 더 좋은 예입니다.

void recursion (int x) {if (x == 0) return; else {puts ("Boop!"); recursion (-x);}}

recursion () 함수는

x 값을 허용합니다. x 가 0과 같으면 기능이 중단됩니다. 그렇지 않으면 함수가 다시 호출되지만 x 의 값은 줄어 듭니다. 감소 프리픽스 연산자는 호출이 이루어지기 전에 x 값이 감소되도록 사용됩니다. -> 예제 recursion () 함수는 기본적으로

Boop!

주어진 횟수. 따라서 recursion ()이 값 10으로 호출되면 해당 텍스트가 10 번 표시됩니다. 재귀에 대한 미친 부분은 함수가 나선형 인 것처럼 함수 자체가 계속해서 더 강력하고 견고하게 포장된다는 것입니다. 앞의 예제에서 조건 x == 1은 마침내 그 twisty 엉망을 풀어 주며 점점 기능이 완료 될 때까지 뒤로 당깁니다. 다음 코드는 recursion () 함수를 사용하는 전체 프로그램을 보여줍니다.

#include void recursion (int x); int main () {재귀 (10); return (0);} 재귀 호출 (int x) {if (x == 0) return; else {puts ("Boop!"); 재귀 (-x);}}

일반적인 재귀 재현은 계승 함수입니다.

팩토리얼

은 값에 양의 정수를 곱한 결과입니다. 예: 4! = 4 × 3 × 2 × 1 이 계승의 결과는 24입니다. 컴퓨터는 루프를 구현하거나 재귀 함수를 작성하여이 계산을 수행 할 수도 있습니다.여기에 그러한 함수가 있습니다:

int factorial (int x) {if (x == 1) return (x); else return (x * factorial (x-1));}

다른 재귀 함수와 마찬가지로 factorial () 함수는 종료 조건 x == 1을 포함합니다. 그렇지 않으면 함수는

x

의 현재 값보다 작은 값으로 다시 호출됩니다. 그러나 모든 조치는 반환 값으로 수행됩니다.

재귀의 맛 - 더미

편집자의 선택

JavaScript에서 HTML 양식 요소에 액세스하는 방법 - 다른 HTML 요소와 마찬가지로

JavaScript에서 HTML 양식 요소에 액세스하는 방법 - 다른 HTML 요소와 마찬가지로

자바 스크립트에서 HTML5 요소와 직접 상호 작용할 수 있습니다. 트릭은 선택한 요소가 지원해야하는 브라우저 및 플랫폼에서 작동하는지 확인하는 것입니다. 이 예제에서는 및 태그를 다음과 같은 솔루션의 일부로 사용하는 방법을 보여줍니다.

CSS 값 정의에 대한 빠른 가이드 구문 - 인형

CSS 값 정의에 대한 빠른 가이드 구문 - 인형

W3C (World Wide Web Consortium)에서 모든 CSS 속성의 구문과 가능한 값을 정의합니다. 정의를 가능한 한 정확하게 만들기 위해 W3C는 CSS 값 정의 구문이라는 공식 시스템을 사용합니다. 정의 구문은 가능한 값을 매우 정확하게 정의하지만 CSS 값 정의 구문을 읽는 중 ...

JavaScript로 동적 HTML 요소를 작성하는 방법 - 더미

JavaScript로 동적 HTML 요소를 작성하는 방법 - 더미

모든 페이지에 대한 특수 효과는 페이지에 동적 HTML 변경 기능을 제공하는 것입니다. 예를 들어 다음 예제와 같이 선택한 요소에 특수 효과를 만들 수 있습니다. function ChangeStyles (event) {// 요소에 대한 참조를 얻습니다. var ThisElement ...

편집자의 선택

Excel 2013 통합 문서의 변경 내용 수락 또는 거부 방법 - 변경 내용 추적을 설정하면 더미

Excel 2013 통합 문서의 변경 내용 수락 또는 거부 방법 - 변경 내용 추적을 설정하면 더미

Excel 2013 통합 문서의 경우 리본의 검토 탭에있는 변경 내용 추적 명령 단추의 드롭 다운 메뉴에서 Alt / RGC를 눌러 변경 내용 적용 / 거부 옵션을 선택하여 수락 또는 거부 할 변경 내용을 결정할 수 있습니다. 이렇게하면 Excel이 강조 표시된 모든 변경 내용을 검토합니다 ...

Excel에서 셀에 설명을 추가하는 방법 2016 - 문자

Excel에서 셀에 설명을 추가하는 방법 2016 - 문자

Excel 2016 워크 시트의 특정 셀에 주석을 달 수 있습니다. 댓글은 스티커 메모의 전자 팝업 버전과 유사합니다. 셀에 주석을 추가하려면 다음과 같이하십시오. 셀 포인터를 이동하거나 주석을 추가 할 셀을 클릭하십시오. 새 주석을 클릭하십시오.

Excel 피벗 테이블에 계산 된 필드를 추가하는 방법 - 더미

Excel 피벗 테이블에 계산 된 필드를 추가하는 방법 - 더미

피벗 테이블 내부의 값을 계산합니다. 계산 된 필드 및 항목을 표에 추가 할 수 있습니다. 계산 된 필드를 추가하면 새로운 행이나 열을 피벗 테이블에 삽입 한 다음 수식을 사용하여 새 행이나 열을 채울 수 있습니다. 예를 들어 다음과 같이 나타납니다.

편집자의 선택

포토샵 CS6에서 히스토리 기능으로 채우기를 사용하는 방법 - 더미

포토샵 CS6에서 히스토리 기능으로 채우기를 사용하는 방법 - 더미

채우기 Adobe Photoshop의 기능 Creative Suite 6는 선택을 원할 때 유용합니다. 특정 상태로 바꿀 영역을 쉽게 선택할 수 있으면 기록으로 채우기 기능을 사용할 수 있습니다. 특정 이미지에서 하늘이 마음에 들지 않는다고 가정 해보십시오. 선택한 항목 ...

Photoshop CS6에서 패싯 필터를 사용하는 방법 -

Photoshop CS6에서 패싯 필터를 사용하는 방법 -

Photoshop CS6의 이미지는 먼지와 스크래치를 줄이거 나 날카로운 모서리를 부드럽게하는 것입니다. 패싯 필터는 포스터 라이징 효과를 사용하여 이미지를 분할합니다. Photoshop CS6에서 이미지를 흐리게 처리하려는 한 가지 이유는 먼지 및 스크래치를 줄이거 나 밝기를 비슷하게하는 픽셀 블록을 모아서 기하학적 모양을 사용하여 단일 값으로 변환하기 때문입니다.

Photoshop CS6에서 손 도구 사용 방법 - 인형

Photoshop CS6에서 손 도구 사용 방법 - 인형

Photoshop CS6 손 도구는 이미지 문서에서 빠르게 이동하고 스크롤 막대와 유사하게 작업하여 작업을보다 신속하게 수행 할 수 있습니다. 손 도구는 손 도구를 클릭 할 필요가 거의 없기 때문에 실제 도구보다 기능이 더 많습니다. 간단히 ...