Add FZOI Codes

This commit is contained in:
2024-06-26 22:14:00 +08:00
parent 8f564ca60e
commit b80791cfad
49 changed files with 1653 additions and 0 deletions

41
FZOI/自然数拆分.cpp Normal file
View File

@ -0,0 +1,41 @@
#include <iostream>
#include <vector>
#include <algorithm>
using namespace std;
void f(int n, int r, vector<int>& vt, int start, int count) {
if (count == 0) {
for (int i = 0; i < vt.size(); i ++ ) {
cout << vt[i];
}
cout << endl;
}
else {
for (int i = start; i >= r; i--) {
vt.push_back(i);
f(n, r - 1, vt, i - 1, count - 1);
vt.pop_back();
}
}
}
int main() {
int n, r;
cin >> n >> r;
vector<int> vt;
f(n, r, vt, n, r);
int t = 1;
for (int i = n; i > n - r; i--) {
t *= i;
}
for (int i = 2; i <= r; i++) {
t /= i;
}
cout << "total=" << t << endl;
return 0;
}