Run ID 作者 问题 语言 测评结果 分数 时间 内存 代码长度 提交时间
99943 scl111104 拆分自然数 C++ 通过 100 243 MS 248 KB 450 2023-08-24 10:44:31

Tests(5/5):


#include<bits/stdc++.h> using namespace std; int n, p[11]={1}, cnt=0, m; void print(int aa){ cout << n << "="; for(int i=1; i<aa; i++) cout << p[i] << "+" ; cout << p [aa] << endl; cnt ++; } void dfs(int a){ for(int i=p[a-1]; i<=m; i++){ if(i == n) continue; p[a] = i; m -= i; if(m == 0) print(a); else dfs(a + 1); m += i; } } int main(){ cin >> n; m = n; dfs(1); cout << cnt; return 0; }


测评信息: