Pagini recente » Cod sursa (job #794795) | Cod sursa (job #705925) | Monitorul de evaluare | Cod sursa (job #2413720) | Cod sursa (job #2711925)
#include <bits/stdc++.h>
using namespace std;
pair <int, int> fib(int n) {
if (!n) return {0, 1};
auto p = fib(n >> 1);
int c = p.first * (2 * p.second - p.first),
d = p.first * p.first + p.second * p.second;
return (n & 1) ? {d, c + d} : {c, d};
}
int main() {
ifstream fin("kfib.in");
ofstream fout("kfib.out");
int n;
fin >> n;
auto ans = fib(n);
fout << ans.first;
return 0;
}