Hướng dẫn giải của THT Long An 2023 - Bảng C - Bài 1
Chỉ dùng lời giải này khi không có ý tưởng, và đừng copy-paste code từ lời giải này. Hãy tôn trọng người ra đề và người làm lời giải.
Nộp code mẫu trước khi tự giải được bài tập là một hành vi có thể bị ban.
Tác giả:
Với ~N \le 10^8~
Ta có thể dùng mảng để tính bằng công thức trên. Vì 1 int
là 4 bytes
nên ~10^8~ int
chỉ có 400000000 bytes
hay chỉ khoảng 400 MB
Với ~N \le 4 \cdot 10^8~
Ta tính trước ~10^8~ phần tử đầu và kết hợp gọi đệ quy để tính các phần tử tiếp theo.
Code tham khảo của
#include <bits/stdc++.h> using namespace std; #define reu(i, a, b) for(int i = a, _b = b; i <= _b; i++) #define red(i, a, b) for(int i = a, _b = b; i >= _b; i--) #define ii pair<int, int> #define fi first #define se second #define M(i) (1LL << (i)) #define INF 1000000 typedef long long ll; const int N = 1e8; int n, d; int a[N+5], ans = 0; int calc(int n){ if (n <= N) return a[n]; if (n%2 == 0) return calc(n/2); else return calc(n/2) + calc(n/2 + 1); } int32_t main(){ ios::sync_with_stdio(0); cin.tie(0); cout.tie(0); a[0] = 0; a[1] = 1; reu(i, 1, N) if (i%2 == 1) a[i] = a[i/2] + a[i/2+1]; else a[i] = a[i/2]; int n; cin >> n; red(i, n, n/2) ans = max(ans, calc(i)); cout << ans; return 0; }
Bình luận