제출 #907254

#제출 시각아이디문제언어결과실행 시간메모리
907254Captain_GeorgiaDetecting Molecules (IOI16_molecules)C++17
100 / 100
43 ms7476 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...