https://www.acmicpc.net/problem/24416
#include <bits/stdc++.h>
#define endl "\n"
using namespace std;
/******** 전역변수 ********/
int fibo[50] = { 0, 1, 1, };
int cnt1 = 0, cnt2 = 0;
/******** 함 수 ********/
int fibonacci(int n) {
if (n == 1 || n == 2) {
cnt1++;
return 1;
}
else return fibonacci(n - 1) + fibonacci(n - 2);
}
int main(void) {
/******** C++ INIT ********/
ios::sync_with_stdio(false);
cin.tie(NULL);
cout.tie(NULL);
/******** 지역변수 ********/
int input;
/******** 구 현 ********/
cin >> input;
fibonacci(input);
cout << cnt1 << " ";
for (int i = 3; i <= input; i++) {
fibo[i] = fibo[i - 1] + fibo[i - 2];
cnt2++;
}
cout << cnt2;
}
'알고리즘' 카테고리의 다른 글
C++ 알고리즘 - 1904 01타일 (0) | 2025.01.22 |
---|---|
C++ 알고리즘 - 9184 신나는 함수 실행 (동적 계획법 / 재귀) (0) | 2025.01.22 |
C++ 알고리즘 - 15652 N과 M (4) (백트래킹) (0) | 2025.01.21 |
C++ 알고리즘 - 15650 N과 M (3) (백트래킹) (0) | 2025.01.21 |
C++ 알고리즘 - 4779 칸토어 집합 (0) | 2025.01.21 |