제출 #1204559

#제출 시각아이디문제언어결과실행 시간메모리
1204559Bui_Quoc_CuongDetecting Molecules (IOI16_molecules)C++20
19 / 100
6 ms784 KiB
#include "molecules.h"|
#include <bits/stdc++.h>
using namespace std;
/*
    tìm tập i1, i2, ... , im

    L <= wi1 + wi2 + ... + wim <= R
    wmax - wmin <= R - L
*/
bitset <(int)1e6> dp;
vector<int> find_subset(int L,int R,vector<int> w)
{
    int n = w.size()-1;
    dp[0] = 1;
    for(int i=0;i<=n;i++) dp|= dp << w[i];

    vector<pair<int,int>> wec;
    for(int i=0;i<=n;i++) wec.push_back({w[i], i});
    sort(wec.begin(),wec.end());

    int sum=-1;
    for(int i=L;i<=R;i++)if(dp.test(i))sum=i;

    vector<int> res;
    for(int i=n;i>=0;i--)
    {
        int val=wec[i].first;
        int id=wec[i].second;
        if(sum >= val && dp[sum - val] == 1)
        {
            sum-= val;
            res.push_back(id);
        }
    }
    sort(res.begin(),res.end());

    return res;
}

컴파일 시 표준 에러 (stderr) 메시지

molecules.cpp:1:23: warning: extra tokens at end of #include directive
    1 | #include "molecules.h"|
      |                       ^
molecules.h:1:9: warning: #pragma once in main file
    1 | #pragma once
      |         ^~~~
molecules_c.h:1:9: warning: #pragma once in main file
    1 | #pragma once
      |         ^~~~
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...