Submission #528724

#TimeUsernameProblemLanguageResultExecution timeMemory
528724groshiDetecting Molecules (IOI16_molecules)C++17
19 / 100
1 ms296 KiB
#include "molecules.h"
#include<iostream>
#include<vector>
#include<map>
#include<algorithm>
using namespace std;
map<long long,int> mapka;
vector<int> t;
vector<int> find_subset(int l,int u,vector<int> w)
{
    long long suma=0;
    mapka[0]=-1;
    for(int i=0;i<w.size();i++)
    {
        suma+=(long long)w[i];
        mapka[suma]=i;
        auto it=mapka.lower_bound(suma-(long long)u);
        if(it==mapka.end())
            continue;
        long long gdzie=it->first;
        if(suma-gdzie>=(long long)l && suma-gdzie<=(long long)u)
        {
            for(int j=it->second+1;j<=i;j++)
            {
                t.push_back(j);
            }
            break;
        }
    }
    return t;
}

Compilation message (stderr)

molecules.cpp: In function 'std::vector<int> find_subset(int, int, std::vector<int>)':
molecules.cpp:13:18: warning: comparison of integer expressions of different signedness: 'int' and 'std::vector<int>::size_type' {aka 'long unsigned int'} [-Wsign-compare]
   13 |     for(int i=0;i<w.size();i++)
      |                 ~^~~~~~~~~
#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...