228942026-01-16 07:51:01IMatyiDíjazás több helyezettnekcpp17Időlimit túllépés 55/80600ms548 KiB
#include <iostream>
#include <cstdlib>
using namespace std;


int st[20],n,top,p, H,E,s=0;
void init(){
    st[top]=st[top-1];

}
int nextel(){
    if (st[top]>1){  //itt meg kell optimizalni
        st[top]--; s--;
        return 1;
    }
    else return 0;
}

int valid(){
    if(s>E) return false;
    if(s<E)
        if(top==H) return false;
        else return true;

    return true;
}

int result(){
    return (s==E) &&(top==H);
}

void write(){
    for(int i=1;i<=H;i++)
        cout<<st[i]<<' ';
    cout<<endl;
}

void backtrack(){
    int vk;
    st[1]=E-(H*(H-1)/2);
    for(int i=2;i<H;i++) st[i]=H-i+1;
    st[H]=2;
    s=E+1;
    top=H;
    //write();
    //init();
    while(top>0){
        do {} while ((vk=nextel()) && !valid());
        if (vk)
            if (result())
                write();
            else {
                top++;init();s=s+st[top];}
        else{
           s=s-st[top]; top--;
        }
    }
}

int main(){
    cin>>H;
    cin>>E;

    backtrack();
}
RészfeladatÖsszpontTesztVerdiktIdőMemória
subtask10/0
1Elfogadva1ms316 KiB
2Elfogadva4ms316 KiB
subtask25/5
3Elfogadva1ms316 KiB
4Elfogadva1ms316 KiB
5Elfogadva1ms316 KiB
6Elfogadva1ms508 KiB
7Elfogadva1ms316 KiB
subtask35/5
8Elfogadva1ms316 KiB
9Elfogadva1ms316 KiB
10Elfogadva1ms316 KiB
11Elfogadva1ms316 KiB
12Elfogadva2ms508 KiB
subtask415/15
13Elfogadva1ms316 KiB
14Elfogadva1ms316 KiB
15Elfogadva1ms316 KiB
16Elfogadva2ms316 KiB
17Elfogadva2ms316 KiB
subtask515/15
18Elfogadva2ms316 KiB
19Elfogadva3ms500 KiB
20Elfogadva3ms316 KiB
21Elfogadva3ms548 KiB
22Elfogadva1ms316 KiB
subtask615/15
23Elfogadva1ms316 KiB
24Elfogadva4ms412 KiB
25Elfogadva2ms316 KiB
26Elfogadva3ms500 KiB
27Elfogadva3ms316 KiB
28Elfogadva3ms548 KiB
29Elfogadva1ms316 KiB
30Elfogadva3ms316 KiB
31Elfogadva4ms316 KiB
32Elfogadva1ms316 KiB
33Elfogadva2ms508 KiB
34Elfogadva6ms316 KiB
35Elfogadva1ms316 KiB
36Elfogadva2ms316 KiB
37Elfogadva12ms508 KiB
38Elfogadva28ms408 KiB
39Elfogadva4ms508 KiB
subtask70/25
40Elfogadva1ms316 KiB
41Elfogadva4ms412 KiB
42Elfogadva1ms316 KiB
43Elfogadva1ms316 KiB
44Elfogadva1ms316 KiB
45Elfogadva1ms508 KiB
46Elfogadva1ms316 KiB
47Elfogadva1ms316 KiB
48Elfogadva1ms316 KiB
49Elfogadva1ms316 KiB
50Elfogadva1ms316 KiB
51Elfogadva2ms508 KiB
52Elfogadva1ms316 KiB
53Elfogadva1ms316 KiB
54Elfogadva1ms316 KiB
55Elfogadva2ms316 KiB
56Elfogadva2ms316 KiB
57Elfogadva2ms316 KiB
58Elfogadva3ms500 KiB
59Elfogadva3ms316 KiB
60Elfogadva3ms548 KiB
61Elfogadva1ms316 KiB
62Elfogadva3ms316 KiB
63Elfogadva4ms316 KiB
64Elfogadva1ms316 KiB
65Elfogadva2ms508 KiB
66Elfogadva6ms316 KiB
67Elfogadva1ms316 KiB
68Elfogadva2ms316 KiB
69Elfogadva12ms508 KiB
70Elfogadva28ms408 KiB
71Elfogadva4ms508 KiB
72Elfogadva361ms408 KiB
73Elfogadva34ms492 KiB
74Időlimit túllépés574ms512 KiB
75Elfogadva2ms316 KiB
76Elfogadva8ms316 KiB
77Időlimit túllépés600ms316 KiB
78Elfogadva4ms316 KiB
79Időlimit túllépés579ms500 KiB
80Elfogadva184ms316 KiB
81Időlimit túllépés583ms508 KiB