248432026-02-16 01:15:03999Díjazás több helyezettnekcpp17Accepted 80/808ms7016 KiB
// Source: https://usaco.guide/general/io

#include <bits/stdc++.h>
#define int long long
using namespace std;

vector<vector<vector<int>>> lehet;

bool lehete(int h,int e,int min){
    if(h==0&&e>=0)return lehet[h][e][min]=true;
    if(e<0)return false;
    if(lehet[h][e][min]>-1)return lehet[h][e][min];
    lehet[h][e][min]=lehete(h-1,e-min,min+1);
    return lehet[h][e][min];
}

vector<vector<int>> solutions(int h,int e,int min){
    if(h==1)return {{e}};
    vector<vector<int>> ans;
    int i=min;
    while(1){
        bool b=(e>=i&&lehet[h-1][e-i][i+1]>-1?lehet[h-1][e-i][i+1]:lehete(h-1,e-i,i+1));
        if(!b){
            break;
        }
        vector<vector<int>> temp=solutions(h-1,e-i,i+1);
        for(vector<int>& vv:temp){
            vv.push_back(i);
            ans.push_back(vv);
        }
        i++;
    }
    return ans;
}

signed main() {
    int h, e;cin>>h>>e;
    lehet.resize(h+1,vector<vector<int>>(e+1,vector<int>(e+1,-1)));
    vector<vector<int>> ans=solutions(h,e,1);
    sort(ans.rbegin(),ans.rend());
    for(auto i:ans){
        for(int j : i){
            cout<<j<<' ';
        }cout<<endl;
    }
}
SubtaskSumTestVerdictTimeMemory
subtask10/0
1Accepted1ms500 KiB
2Accepted4ms1076 KiB
subtask25/5
3Accepted1ms316 KiB
4Accepted1ms316 KiB
5Accepted1ms316 KiB
6Accepted1ms316 KiB
7Accepted1ms564 KiB
subtask35/5
8Accepted1ms316 KiB
9Accepted1ms316 KiB
10Accepted1ms500 KiB
11Accepted1ms316 KiB
12Accepted3ms820 KiB
subtask415/15
13Accepted1ms316 KiB
14Accepted1ms316 KiB
15Accepted1ms316 KiB
16Accepted2ms316 KiB
17Accepted3ms564 KiB
subtask515/15
18Accepted1ms316 KiB
19Accepted3ms564 KiB
20Accepted3ms564 KiB
21Accepted3ms688 KiB
22Accepted1ms564 KiB
subtask615/15
23Accepted1ms316 KiB
24Accepted4ms1076 KiB
25Accepted1ms316 KiB
26Accepted3ms564 KiB
27Accepted3ms564 KiB
28Accepted3ms688 KiB
29Accepted1ms564 KiB
30Accepted4ms820 KiB
31Accepted4ms820 KiB
32Accepted1ms564 KiB
33Accepted1ms848 KiB
34Accepted4ms1248 KiB
35Accepted1ms792 KiB
36Accepted2ms820 KiB
37Accepted6ms1332 KiB
38Accepted6ms1856 KiB
39Accepted2ms1588 KiB
subtask725/25
40Accepted1ms316 KiB
41Accepted4ms1076 KiB
42Accepted1ms316 KiB
43Accepted1ms316 KiB
44Accepted1ms316 KiB
45Accepted1ms316 KiB
46Accepted1ms564 KiB
47Accepted1ms316 KiB
48Accepted1ms316 KiB
49Accepted1ms500 KiB
50Accepted1ms316 KiB
51Accepted3ms820 KiB
52Accepted1ms316 KiB
53Accepted1ms316 KiB
54Accepted1ms316 KiB
55Accepted2ms316 KiB
56Accepted3ms564 KiB
57Accepted1ms316 KiB
58Accepted3ms564 KiB
59Accepted3ms564 KiB
60Accepted3ms688 KiB
61Accepted1ms564 KiB
62Accepted4ms820 KiB
63Accepted4ms820 KiB
64Accepted1ms564 KiB
65Accepted1ms848 KiB
66Accepted4ms1248 KiB
67Accepted1ms792 KiB
68Accepted2ms820 KiB
69Accepted6ms1332 KiB
70Accepted6ms1856 KiB
71Accepted2ms1588 KiB
72Accepted8ms3124 KiB
73Accepted3ms2660 KiB
74Accepted7ms3892 KiB
75Accepted3ms3140 KiB
76Accepted4ms4016 KiB
77Accepted7ms5036 KiB
78Accepted4ms5284 KiB
79Accepted8ms6068 KiB
80Accepted6ms6876 KiB
81Accepted6ms7016 KiB