QOJ.ac

QOJ

IDProblemSubmitterResultTimeMemoryLanguageFile sizeSubmit timeJudge time
#828647#9913. 绝顶之战Daniel77730 4ms4980kbC++141.9kb2024-12-23 19:15:022024-12-23 19:15:03

Judging History

你现在查看的是最新测评结果

  • [2024-12-23 19:15:03]
  • 评测
  • 测评结果:30
  • 用时:4ms
  • 内存:4980kb
  • [2024-12-23 19:15:02]
  • 提交

answer

#include<bits/stdc++.h>
using namespace std;
typedef long long ll;
const int N = 14;
ll m;
int n,lim;
ll a[N];
int k;
int f[1<<N],g[1<<N];
ll sum[1<<N],cs[1<<N];
map<ll,int>mp;
vector<ll>vec;
void fmt(int A[])
{
    for(int i = 1;i < (1<<k);i<<=1)
        for(int j = 0;j < (1<<k);j+=i<<1)
            for(int l = 0;l < i;l++)
                A[i+j+l] += A[j+l];
    for(int i = 0;i < (1<<k);i++) A[i] *= A[i];
    for(int i = 1;i < (1<<k);i<<=1)
        for(int j = 0;j < (1<<k);j+=i<<1)
            for(int l = 0;l < i;l++)
                A[i+j+l] -= A[j+l];
    for(int i = 0;i < (1<<k);i++) if(A[i] > 0) A[i] = 1;
}
void work(int S)
{
    if(mp[sum[S]]) return ;
    if(sum[S] > m) return ;
    //cout<<S<<"\n";
    int cnt = 0;
    ll cur = 0;
    for(int i = 0;i < n;i++)
    {
        if(S & (1<<i))
        {
            cur += a[i];
            cnt++;
        }
        else if(cur + 1ll*a[i]*(cnt+1) <= m) return ;
    }
    k = 0;
    f[0] = 1;
    //cout<<S<<"\n";
    for(int i = n-1;i >= 0;i--)
    {
        //cout<<i<<"\n";
        if(S & (1<<i))
        {
            for(int j = 0;j < (1<<k);j++) g[j] = f[j];
            fmt(g);
            for(int j = (1<<k);j < (1<<k+1);j++) cs[j] = cs[j^(1<<k)] + a[i],f[j] = g[j^(1<<k)];
            ++k;
        }
        else
        {
            for(int j = 0;j < (1<<k);j++) if(cs[j] > a[i]) f[j] = 0;
        }
    }
    //cout<<S<<"\n";
    //cout<<S<<" "<<f[(1<<k)-1]<<"\n";
    if(f[(1<<k)-1]) mp[sum[S]] = 1,vec.push_back(sum[S]);
}
int main()
{
    ios::sync_with_stdio(false);cin.tie(0);
    cin>>m>>n;lim = (1<<n);
    for(int i = 0;i < n;i++) cin>>a[i];
    for(int i = 1;i < lim;i++)
    {
        int lb = __builtin_ctz(i);
        sum[i] = sum[i^(1<<lb)] + a[lb];
    }
    for(int S = 0;S < lim;S++) work(S);
    cout<<vec.size()<<"\n";
    sort(vec.begin(),vec.end());
    for(auto x:vec) cout<<x<<" ";
    cout<<"\n";
    return 0;
}

Details

Tip: Click on the bar to expand more detailed information

Subtask #1:

score: 15
Accepted

Test #1:

score: 15
Accepted
time: 0ms
memory: 3720kb

input:

9 5
5 4 5 3 5

output:

3
5 8 9 

result:

ok 4 number(s): "3 5 8 9"

Test #2:

score: 15
Accepted
time: 0ms
memory: 3644kb

input:

10 5
7 4 5 4 6

output:

1
7 

result:

ok 2 number(s): "1 7"

Test #3:

score: 15
Accepted
time: 0ms
memory: 3676kb

input:

9 5
8 4 3 5 6

output:

1
8 

result:

ok 2 number(s): "1 8"

Test #4:

score: 15
Accepted
time: 0ms
memory: 3664kb

input:

10 5
6 6 5 4 5

output:

2
6 10 

result:

ok 3 number(s): "2 6 10"

Test #5:

score: 15
Accepted
time: 0ms
memory: 3656kb

input:

10 5
6 6 5 3 4

output:

2
6 9 

result:

ok 3 number(s): "2 6 9"

Subtask #2:

score: 5
Accepted

Test #6:

score: 5
Accepted
time: 0ms
memory: 3640kb

input:

9146201596026093 2
1959292328727211 3046691025174768

output:

1
5005983353901979 

result:

ok 2 number(s): "1 5005983353901979"

Test #7:

score: 5
Accepted
time: 0ms
memory: 3672kb

input:

9275681991750590 2
5186569060202341 3113841469169509

output:

2
5186569060202341 8300410529371850 

result:

ok 3 number(s): "2 5186569060202341 8300410529371850"

Test #8:

score: 5
Accepted
time: 0ms
memory: 3600kb

input:

9401675366106951 2
149091771205127 6947611558612479

output:

2
149091771205127 7096703329817606 

result:

ok 3 number(s): "2 149091771205127 7096703329817606"

Test #9:

score: 5
Accepted
time: 0ms
memory: 3588kb

input:

9392557811857168 2
160423759804827 7346645029161642

output:

2
160423759804827 7507068788966469 

result:

ok 3 number(s): "2 160423759804827 7507068788966469"

Test #10:

score: 5
Accepted
time: 0ms
memory: 3668kb

input:

9822837057566509 2
108146351103958 7480790958348985

output:

2
108146351103958 7588937309452943 

result:

ok 3 number(s): "2 108146351103958 7588937309452943"

Subtask #3:

score: 5
Accepted

Test #11:

score: 5
Accepted
time: 0ms
memory: 3668kb

input:

9107037180352846 3
2775941126614211 2097129959011760 1941377836547846

output:

2
4873071085625971 6814448922173817 

result:

ok 3 number(s): "2 4873071085625971 6814448922173817"

Test #12:

score: 5
Accepted
time: 0ms
memory: 3660kb

input:

9356790767702598 3
5546180935211679 2905945428392309 1761953813389806

output:

2
7308134748601485 8452126363603988 

result:

ok 3 number(s): "2 7308134748601485 8452126363603988"

Test #13:

score: 5
Accepted
time: 0ms
memory: 3716kb

input:

9850427814943989 3
142199778279844 6707702417646007 5098690319392154

output:

3
142199778279844 5240890097671998 6849902195925851 

result:

ok 4 number(s): "3 142199778279844 5240890097671998 6849902195925851"

Test #14:

score: 5
Accepted
time: 0ms
memory: 3576kb

input:

9289721094295218 3
158922512595425 6720813049590970 5533326304480556

output:

3
158922512595425 5692248817075981 6879735562186395 

result:

ok 4 number(s): "3 158922512595425 5692248817075981 6879735562186395"

Test #15:

score: 5
Accepted
time: 0ms
memory: 3672kb

input:

9089829946377332 3
153331859334767 6955566390185762 5391139066021841

output:

3
153331859334767 5544470925356608 7108898249520529 

result:

ok 4 number(s): "3 153331859334767 5544470925356608 7108898249520529"

Subtask #4:

score: 5
Accepted

Test #16:

score: 5
Accepted
time: 0ms
memory: 3672kb

input:

9035514376902827 5
1861522865446152 1901640741231313 2239047273044626 2596933481542076 2408801444166990

output:

4
3763163606677465 6002210879722091 8411012323889081 8599144361264167 

result:

ok 5 number(s): "4 3763163606677465 60022108797...11012323889081 8599144361264167"

Test #17:

score: 5
Accepted
time: 0ms
memory: 3656kb

input:

9720759307951601 5
5245904226180530 3078325181926984 1664005610640026 897140663439037 545770017429336

output:

5
7807050500259593 8324229408107514 8352820517688929 8869999425536850 9221370071546551 

result:

ok 6 numbers

Test #18:

score: 5
Accepted
time: 0ms
memory: 3712kb

input:

9914984513811788 5
143280160480180 109619234770197 6890320393268943 5403376030977054 4137173786378446

output:

5
252899395250377 4390073181628823 5656275426227431 7143219788519320 9793449212605877 

result:

ok 6 numbers

Test #19:

score: 5
Accepted
time: 1ms
memory: 3720kb

input:

9759176874761010 5
133219343571190 120466941665747 6704653967672701 5571405145717257 4167138211880141

output:

4
253686285236937 4420824497117078 5825091430954194 6958340252909638 

result:

ok 5 number(s): "4 253686285236937 442082449711...25091430954194 6958340252909638"

Test #20:

score: 5
Accepted
time: 0ms
memory: 3580kb

input:

9525506737874968 5
148963131354572 158578418411159 6828452733024137 5381364252000234 4049653682935737

output:

4
307541549765731 4357195232701468 5688905801765965 7135994282789868 

result:

ok 5 number(s): "4 307541549765731 435719523270...88905801765965 7135994282789868"

Subtask #5:

score: 0
Wrong Answer

Test #21:

score: 5
Accepted
time: 0ms
memory: 3600kb

input:

9023163981511792 7
1910131726862762 2116561201938147 2221366112235172 2543084904983947 2627118050952859 1894287864736168 2673898998406780

output:

5
4026692928800909 5920980793537077 6248059041036081 8142346905772249 8791143946020028 

result:

ok 6 numbers

Test #22:

score: 5
Accepted
time: 0ms
memory: 3608kb

input:

9201962815585483 7
5414508209828189 3093292941553917 1685274817103741 948835864411768 509817155946068 281984678231046 159476022063405

output:

11
8051060883172449 8490079591638149 8558436047289766 8667277173445511 8717912069353171 8789785829613152 8840420725520812 8949261851676557 8999896747584217 9017618307328174 9177094329391579 

result:

ok 12 numbers

Test #23:

score: 0
Wrong Answer
time: 0ms
memory: 3604kb

input:

9826610363201771 7
162505577758383 135338647957173 6721075735733948 5272016953171334 3778424372952824 2933545141068482 2192801947755330

output:

12
3231389366784038 4076268598668380 5424191314539368 5569861178886890 6269070546423710 7009813739736862 7018919961449504 7762663126642220 8503406319955372 9202615687492192 9211721909204834 9348285551839714 

result:

wrong answer 1st numbers differ - expected: '11', found: '12'

Subtask #6:

score: 0
Wrong Answer

Test #26:

score: 5
Accepted
time: 0ms
memory: 3728kb

input:

9843534281138117 9
2077071368628181 2828099538983996 3196114494343630 3055890563571162 2057088847509186 2194463607939255 2091779370708588 3167995993737888 2800516708286895

output:

6
4905170907612177 6962259755121363 7961061471183339 8101285401955807 9054039125829951 9156723363060618 

result:

ok 7 numbers

Test #27:

score: 0
Wrong Answer
time: 0ms
memory: 3636kb

input:

9089321288577479 9
5013478738969552 3157961240306159 1653601571668037 995106965792662 547346063380849 294963106466152 160268607573676 93635792107328 51921499739784

output:

18
7815215379905378 8262976282317191 8515359239231888 8611960377588975 8650053738124364 8678593193055323 8716686553590712 8758400845958256 8770707542396344 8772228985162651 8810322345698040 8864343334503672 8879054650230236 8930976149970020 8972690442337564 9013749149122712 9024611942077348 90656706...

result:

wrong answer 1st numbers differ - expected: '17', found: '18'

Subtask #7:

score: 0
Wrong Answer

Test #31:

score: 10
Accepted
time: 0ms
memory: 3812kb

input:

9431564240371856 11
2072502046158126 2066316271517661 2163529290633843 2033552924777258 2060295112538633 2170963915845858 2830153069449699 2750192266102216 2436460356484587 2070428523960501 2346826281628005

output:

5
4138818317675787 6172371242453045 6302347608309630 8232666354991678 8335900533086888 

result:

ok 6 numbers

Test #32:

score: 0
Wrong Answer
time: 1ms
memory: 3752kb

input:

9748017886882097 11
5621106261846239 2963693598568387 1770987181252029 893130050604348 502107706153055 286239930406429 177406459478434 98736836706145 50305470562766 29068874911746 16153459380560

output:

37
8552112180697403 8943134525148696 9159002300895322 9242710891860706 9267835771823317 9281172208128898 9346505394595606 9359841830901187 9394936760738985 9445242231301751 9458578667607332 9468675301829182 9517106667972561 9567412138535327 9573457715874046 9595776290744850 9617012886395870 96218890...

result:

wrong answer 1st numbers differ - expected: '35', found: '37'

Subtask #8:

score: 0
Wrong Answer

Test #36:

score: 10
Accepted
time: 1ms
memory: 3952kb

input:

9205033666499013 12
2850462003249404 2805242660077069 2429054981777503 2963815386637346 2482550367349595 1986471485219802 2520994127845999 2437529223970625 2627469170446910 1921642320209105 2645728927620059 2290578758228158

output:

4
5655704663326473 7577346983535578 7642176148546275 8084759645103976 

result:

ok 5 number(s): "4 5655704663326473 75773469835...42176148546275 8084759645103976"

Test #37:

score: 0
Wrong Answer
time: 0ms
memory: 3920kb

input:

9312008144548179 12
5098312777552324 2828210584202914 1698846116084863 972763022136388 536323112196116 296239601985823 168374174447656 95736456798989 55681139272124 31357956485449 16061655649327 9384457843970

output:

38
8006317448316641 8442757358256913 8599358804238576 8682840868467206 8810706296005373 8839442314448869 8883344013654040 8923399331180905 8967307741987036 8979080470453029 9039945459635703 9080000777162568 9104323959949243 9107508049941485 9124464628318028 9135681916434692 9180145767590152 91888431...

result:

wrong answer 1st numbers differ - expected: '37', found: '38'

Subtask #9:

score: 0
Wrong Answer

Test #41:

score: 10
Accepted
time: 2ms
memory: 4168kb

input:

9386101775874151 13
2988434015746527 2531638596517047 2952017129004226 2532501379103299 2134686632728924 2723134092613376 2734705006477432 2790707225133977 2417142090510094 2242777209869653 2707931539021407 2508571481588074 2833570313484694

output:

4
5520072612263574 7654759244992498 8052573991366873 8472089741267800 

result:

ok 5 number(s): "4 5520072612263574 76547592449...52573991366873 8472089741267800"

Test #42:

score: 0
Wrong Answer
time: 2ms
memory: 4292kb

input:

9168182173116105 13
5245945745965630 2966339978381958 1587236525258288 896003981667415 529285939890159 293959638682944 169587396142065 91544716767044 52705601201500 28282607177863 17370633326495 9113216610963 5470267979344

output:

52
8030502289002295 8397220330779551 8632546631986766 8710732406093741 8756918874527645 8834961553902666 8873800669468210 8880319802235806 8926506270669710 8946058707300956 8971395785474477 9024101386675977 9034657895063658 9062940502241521 9067485420837493 9069992862938663 9087363496265158 90957680...

result:

wrong answer 1st numbers differ - expected: '47', found: '52'

Subtask #10:

score: 0
Wrong Answer

Test #46:

score: 30
Accepted
time: 3ms
memory: 4804kb

input:

9001324849976175 14
2825925335672803 2025589127489736 2269614904415361 1837491879093462 2158539836494236 2426078823971452 1924825856346157 2746394845754343 2268412247933575 2230951690565408 2494052463977166 2855920747842645 2234733913430870 2001499177846439

output:

6
4851514463162539 6689006342256001 7121129367577900 8613832198602158 8847546178750237 8958621246671362 

result:

ok 7 numbers

Test #47:

score: 0
Wrong Answer
time: 4ms
memory: 4980kb

input:

9972282568532949 14
5505337530293470 3041608956429561 1641948100087404 921229203322626 522006830353828 305104880869052 169979965880291 98139538460294 50438074200129 30572008666021 16022716436664 9778663336212 5597214430013 3030746040166

output:

53
8757178642022342 8974080591507118 9235610295041873 9279185472376170 9452512244526649 9587637159515410 9659477586935407 9681754651615156 9707179051195572 9753595079035153 9757617125395701 9801296543295318 9821162608829426 9838281919823785 9851734617495447 9858147985357893 9888719994023914 99058494...

result:

wrong answer 1st numbers differ - expected: '52', found: '53'