This submission is migrated from previous version of oj.uz, which used different machine for grading. This submission may have different result if resubmitted.
#include <iostream>
#include <stdio.h>
#include <stdlib.h>
#include <vector>
#include "molecules.h"
using namespace std;
bool have[10005][10005]={0};
bool can[10005][10005][5]={0};
bool F(int N,int l,int r,vector < int > &w)
{
if(r<0) return 0;
if(l<=0&&0<=r) return 1;
if(l<=w[N]&&w[N]<=r) return 1;
if(N==0) return 0;
if(have[N][r]) return can[N][r][0]||can[N][r][1];
can[N][r][0]=F(N-1,l,r,w);
can[N][r][1]=F(N-1,l-w[N],r-w[N],w);
have[N][r]=1;
return can[N][r][0]||can[N][r][1];
}
void solve(int N,int l,int r,vector < int > &ans,vector < int > &w)
{
//printf("%d %d %d\n",N,l,r);
if(r<0) return;
if(l<=0&&0<=r) return;
if(l<=w[N]&&w[N]<=r)
{
ans.push_back(N);
return;
}
if(N==0) return;
if(can[N][r][0]) solve(N-1,l,r,ans,w);
else
{
ans.push_back(N);
solve(N-1,l-w[N],r-w[N],ans,w);
}
}
vector < int > find_subset(int l, int u, vector < int > w)
{
int N=w.size();
vector < int > ans;
if(F(N-1,l,u,w)) solve(N-1,l,u,ans,w);
return ans;
}
| # | Verdict | Execution time | Memory | Grader output |
|---|
| Fetching results... |
| # | Verdict | Execution time | Memory | Grader output |
|---|
| Fetching results... |
| # | Verdict | Execution time | Memory | Grader output |
|---|
| Fetching results... |
| # | Verdict | Execution time | Memory | Grader output |
|---|
| Fetching results... |
| # | Verdict | Execution time | Memory | Grader output |
|---|
| Fetching results... |
| # | Verdict | Execution time | Memory | Grader output |
|---|
| Fetching results... |