QOJ.ac

QOJ

IDProblemSubmitterResultTimeMemoryLanguageFile sizeSubmit timeJudge time
#701969#7739. Knapsackhellocccl#WA 6ms8524kbC++201.9kb2024-11-02 15:01:142024-11-02 15:01:26

Judging History

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

  • [2024-11-02 15:01:26]
  • 评测
  • 测评结果:WA
  • 用时:6ms
  • 内存:8524kb
  • [2024-11-02 15:01:14]
  • 提交

answer

//ALL IN
//#pragma GCC optimize("Ofast")
//#pragma GCC optimize("Ofast,no-stack-protector,unroll-loops,fast-math")
//#pragma GCC target("sse,sse2,sse3,ssse3,sse4.1,sse4.2,avx,avx2,popcnt,tune=native")
#include<bits/stdc++.h>
using namespace std;
using ll=long long;
#define int long long
#define double long double
const int N=2e5+7;
const int mod=1e9+7;
const int inf=4e18;
mt19937 rnd(time(0));
clock_t start,over;// start=clock(); last=(final-over)*1.0/1000
inline int read(){int x=0,f=1;char ch=getchar();while(ch<'0'||ch>'9'){if(ch=='-')f=-1;ch=getchar();}while(ch>='0'&&ch<='9'){x=x*10+ch-'0',ch=getchar();}return x*f;}
inline void write(int x){if(x<0)putchar('-'),x=-x;if(x>9)write(x/10);putchar(x%10+'0');return;}
int a[N];
int f[N];
set<int>st;
map<pair<int,int>,int>mp;
struct node{
    int w,v;
}good[N];
void solve(){
    int  n,W,k;cin>>n>>W>>k;
    for(int i=1;i<=n;i++){
        cin>>good[i].w>>good[i].v;
    }
    for(int i=1;i<=n;i++){
        for(int j=W;j>=good[i].w;j--){
            int x=f[j-good[i].w]+good[i].v;
            if(x>f[j]){
                mp[{i,j}]=j-good[i].w;
                f[j]=x;
            }else{
                mp[{i,j}]=j;
            }
        }
    }
    int ans=f[W];
    int now=W;
    for(int i=n;i>=1;i--){
        if(mp[{i,now}]==now){
            continue;
        }else if(mp[{i,now}]!=0){
            int x=mp[{i,now}];
            now=x;
            st.insert(i);
        }
    }
    // cout<<ans<<'\n';
    vector<int>v;
    for(int i=1;i<=n;i++){
        if(not st.count(i)){
            // cout<<i<<'\n';
            v.push_back(good[i].v);
        }
    }
    sort(v.begin(),v.end());
    for(int i=1;i<=k and i<=v.size();i++){
        ans+=v[v.size()-i];
    }
    cout<<ans<<'\n';
}

signed main(){
    ios::sync_with_stdio(0),cin.tie(0),cout.tie(0);
    int _=1;
    // cin>>_;
    while(_--)solve();
}

Details

Tip: Click on the bar to expand more detailed information

Test #1:

score: 100
Accepted
time: 1ms
memory: 5716kb

input:

4 10 1
9 10
10 1
3 5
5 20

output:

35

result:

ok 1 number(s): "35"

Test #2:

score: 0
Accepted
time: 1ms
memory: 5700kb

input:

5 13 2
5 16
5 28
7 44
8 15
8 41

output:

129

result:

ok 1 number(s): "129"

Test #3:

score: 0
Accepted
time: 0ms
memory: 5880kb

input:

10 50 1
44 182173741
38 163268500
36 114173760
30 521894533
25 89514235
12 516184197
42 971377551
35 28242326
31 480227821
31 388523197

output:

2009456281

result:

ok 1 number(s): "2009456281"

Test #4:

score: 0
Accepted
time: 0ms
memory: 5712kb

input:

10 100 3
23 51015869
9 981426050
76 243762017
64 128189636
4 718411601
48 250140255
17 340478117
68 262055220
40 370503079
4 547232664

output:

3765024872

result:

ok 1 number(s): "3765024872"

Test #5:

score: 0
Accepted
time: 1ms
memory: 6080kb

input:

10 500 10
430 981427684
100 458631577
32 453298334
393 716958962
82 120486064
393 561149128
182 518807793
293 950335710
332 159193263
331 280711850

output:

5201000365

result:

ok 1 number(s): "5201000365"

Test #6:

score: 0
Accepted
time: 2ms
memory: 6780kb

input:

10 3000 10
1325 563890842
2007 190665722
1393 874490922
548 279594682
1380 155046921
2666 894516819
770 740325614
2735 643777488
2451 754155860
1068 138544189

output:

5235009059

result:

ok 1 number(s): "5235009059"

Test #7:

score: 0
Accepted
time: 6ms
memory: 8524kb

input:

10 10000 5
108 735534045
6250 87364128
3071 66920092
9343 555321302
9070 759896065
9843 146885261
3083 364637443
7088 370871572
7802 754417134
3125 697204945

output:

4451687859

result:

ok 1 number(s): "4451687859"

Test #8:

score: -100
Wrong Answer
time: 0ms
memory: 5936kb

input:

100 50 61
24 517916473
33 497071404
40 343150837
13 559776223
2 941245278
27 987936903
7 403293890
26 68412861
28 683505315
6 173482637
31 220799032
29 815472376
42 426462445
25 470177395
43 818534622
26 137556071
15 308105056
27 745044655
28 309413241
11 61130780
36 963194467
19 701095156
5 9347020...

output:

45408572821

result:

wrong answer 1st numbers differ - expected: '44747553879', found: '45408572821'