• 회원가입
  • 로그인
  • 구글아이디로 로그인

[method] Java - Recursion (재귀)

1,449  
목차
  1. Java Recursion (재귀)
  2. 재귀 예제
  3. 재귀 무한 반복을 막는 정지 조건

 

Java Recursion (재귀)

※ 메서드는 함수의 일종.

 

1.

재귀 : 함수 안에서 함수 자신 호출.

 

2.

가장 안쪽 함수의 반환값 이용해,

밖으로 거슬러 나오며 결과 반환.

 

※ 사용 시, 주의 !! 

더 간결할 수도, 때론 훨씬 더 복잡할 수도 있음.

또한, 정지조건 없을 시, 무한 반복 되니 주의 !!

 

 

재귀 예제

※ 1부터 4까지 합.

 

public class Hz {

  public static void main(String[] args) {

    int result = sum(4);

    System.out.println(result);

  }

  public static int sum(int k) {

    if (k > 0) {

      return k + sum(k - 1);

    } else {

      return 0;

    }

  }

}

 

결과값: 10


PS. 작동 원리

 

sum(4) = 4 + sum(3)

sum(3) = 3 + sum(2)

sum(2) = 2 + sum(1)

sum(1) = 1 + 0 = 1

sum(2) = 2 + 1 = 3

sum(3) = 3 + 3 = 6

sum(4) = 4  + 6 = 10

 

 

재귀 무한 반복을 막는 정지 조건

 

모든 재귀함수는 정지 조건 (= 재귀 무한 반복 막는 조건)갖어야 함.

위 예제 경우, k=0 조건이 반복 정지 조건.

아래 예제는, end > start 조건이 반복 정지 조건.

 


[예제] 1부터 4까지의 합.


public class Hz {

  public static void main(String[] args) {

    int result = sum(1, 4);

    System.out.println(result);

  }

  public static int sum(int start, int end) {

    if (end > start) {

      return end + sum(start, end - 1);

    } else {

      return end;

    }

  }

}

 

결과값: 10


PS. 작동원리.

 

sum(1, 4) = 4 + sum(1, 3)

sum(1, 3) = 3 + sum(1, 2)

sum(1, 2) = 2 + sum(1, 1)

sum(1, 1) = 1

sum(1, 2) = 2 + 1 = 3

sum(1, 3) = 3 + 3 = 6

sum(1, 4) = 4 + 6 = 10

 



분류 제목
class Java - LinkedList (링크트리스트) - 반복 접근 최적화 된 유사 배열
class Java - HashMap (해시맵) - key=value 쌍의 유사 배열. (Python Dictionar…
class Java - HashSet (해시셋) - 유일값만 인정하는 유사 배열. ※ Python의 Set과 유사.
class Java - Iterator (반복자)
class Java - Wrapper Classes (랩퍼 클래스)
class Java - Exceptions (= Try...Catch..) - 에러 제어 (= 익셉션 = 트라이...캐…
class Java - RegEx (정규식) - 정규표현식
class Java - Threads (쓰레드)
class Java - Lambda (람다 표현식)
file Java - File 클래스 + 메서드
file Java - Create/Write Files (파일 생성/쓰기)
file Java - Read Files (파일 읽기) - 파일 정보 얻기
file Java - Delete Files (파일 삭제)
Keyword Java - Keywords (키워드) 종류
Keyword Java - abstract 키워드 - 추상 (클래스/메서드) 선언.
Keyword Java - assert 키워드 △ - 디버깅 할 때 사용.
Keyword Java - boolean 키워드 - 참거짓 자료형 지정.
Keyword Java - break 키워드 - (반복문・switch 조건문) 탈출. (= 브레이크)
Keyword Java - byte 키워드 - 1byte 크기의 '정수형' 자료형 지정. (= 바이트)
Keyword Java - case 키워드 - switch 조건문의 각 조건 지정.
3/10
목록
찾아주셔서 감사합니다. Since 2012