제출 #875723

#제출 시각아이디문제언어결과실행 시간메모리
875723Elvin_FritlDetecting Molecules (IOI16_molecules)C++17
100 / 100
39 ms5324 KiB
#include <bits/stdc++.h>
using namespace std;

typedef long long ll;

const int N = 1e5 + 545 , inf = 1e9 + 199;

#include "molecules.h"

vector<int> find_subset(int left, int right, vector<int> w){
    ll n = w.size();
    ll l = 0 , r = 0;
    ll sum = 0;
    vector<pair<ll,ll>>a(n);
    for(int i=0;i<n;i++) {
		a[i].first = w[i];
		a[i].second = i;
	}
	sort(a.begin() , a.end());
    vector<int> res;
    for(int i=0;i<n;i++) {
		sum += a[i].first;
		while(sum > right && l < i) {
			sum -= a[l++].first;
		}
		if(sum >= left && sum <= right) {
			for(int j=l;j<=i;j++){
				res.push_back(a[j].second);
		    }
		    break;
		}
	 }
	 if(sum < left || sum > right) {
		 return res;
	 }
	 return res;
}

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

molecules.cpp: In function 'std::vector<int> find_subset(int, int, std::vector<int>)':
molecules.cpp:12:16: warning: unused variable 'r' [-Wunused-variable]
   12 |     ll l = 0 , r = 0;
      |                ^
#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...