귀환 면접은 항상 시험을 쳐서 여기에 놓는다
import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;
import java.util.HashMap;
import java.util.Iterator;
import java.util.Map;
import java.util.Set;
/**
*
*
* @author Administrator
*
*/
public class Recursion {
/**
* @param args
*/
public static void main(String[] args) {
// TODO Auto-generated method stub
BufferedReader strin=new BufferedReader(new InputStreamReader(System.in));
int n=0;
try {
System.out.println(" 50 :");
n=Integer.parseInt(strin.readLine());
} catch (NumberFormatException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
System.out.println(Fibonacci.fibonacci(n));
Fibonacci.printMap();
}
}
/**
*
*
*
* @author Administrator
*
*/
class Fibonacci{
private static Map m=new HashMap();// n
static long fibonacci(int n){
if(n<=1) return 1;
// !
if(m.containsKey(n))
return (long)m.get(n);
long store=fibonacci(n-1)+fibonacci(n-2);
m.put(n, store);
return store;
}
/**
* m
* map
*/
public static void printMap(){
Set keySet = m.keySet();
Iterator keys=keySet.iterator();
while(keys.hasNext()){
int temp=(int)keys.next();
System.out.println(temp+":"+m.get(temp));
}
}
}
피보나치: 귀속 알고리즘
필기시험은 항상 보는데 여기에 두어라.
1) 최적화를 했다.(캐시)원리: 이미 구한 피보나치 결과를 클래스 변수로 저장하고 메모리에 이 결과가 있으면 다시 계산하지 않고 바로 되돌아갈 수 있다.
2) 맵 인쇄
이 내용에 흥미가 있습니까?
현재 기사가 여러분의 문제를 해결하지 못하는 경우 AI 엔진은 머신러닝 분석(스마트 모델이 방금 만들어져 부정확한 경우가 있을 수 있음)을 통해 가장 유사한 기사를 추천합니다:
다양한 언어의 JSONJSON은 Javascript 표기법을 사용하여 데이터 구조를 레이아웃하는 데이터 형식입니다. 그러나 Javascript가 코드에서 이러한 구조를 나타낼 수 있는 유일한 언어는 아닙니다. 저는 일반적으로 '객체'{}...
텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
CC BY-SA 2.5, CC BY-SA 3.0 및 CC BY-SA 4.0에 따라 라이센스가 부여됩니다.