Submission #251033

# Submission time Handle Problem Language Result Execution time Memory
251033 2020-07-20T00:30:54 Z IsaacMoris Minerals (JOI19_minerals) C++14
40 / 100
122 ms 6900 KB
#include<iostream>
#include <bits/stdc++.h>
#include "minerals.h"
#define ll long long
#define ld long double
#define IO ios_base::sync_with_stdio(0); cin.tie(0); cout.tie(0);
using namespace std;
int low[100009], high[100009];
vector<int> v[100009];

void Solve(int N)
{
    vector<int> v1, v2;
    int last=0;
    for (int i = 1; i <= 2 * N; ++i)
    {
        int x=Query(i);
        if(x!=last)
            v1.push_back(i);
        else
            v2.push_back(i);
        last=x;
    }
    for(int i=0; i<100; i++)
        random_shuffle(v1.begin(),v1.end());
    for(int i=0; i<N; i++)
        high[i]=N-1, low[i]=0;
    int good=1;
    bool p=1;
    while(good)
    {
        good=0;
        for(int i=0; i<N; i++)
            if(low[i]<=high[i])
                v[(int)(low[i]+ (high[i]-low[i])*0.382)].push_back(i);
        for(int i=0; i<N; i++)
        {

            int x=Query(v1[i]);
            while(!v[i].empty())
            {
                int id=v[i].back();

                good=1;
                v[i].pop_back();
                int q=Query(v2[id]);
                if((q!=x && p) || (q==x && !p))
                    high[id]=i-1;
                else
                    low[id]=i+1;
                x=q;
            }
        }
        p=!p;
    }
    for(int i=0; i<N; i++)
        Answer(v2[i], v1[high[i]+1]);

}
# Verdict Execution time Memory Grader output
1 Correct 2 ms 2688 KB Output is correct
2 Correct 2 ms 2688 KB Output is correct
3 Correct 2 ms 2688 KB Output is correct
4 Correct 2 ms 2688 KB Output is correct
# Verdict Execution time Memory Grader output
1 Correct 5 ms 2816 KB Output is correct
2 Correct 8 ms 2944 KB Output is correct
3 Correct 15 ms 3200 KB Output is correct
4 Correct 29 ms 3704 KB Output is correct
5 Correct 53 ms 4772 KB Output is correct
# Verdict Execution time Memory Grader output
1 Correct 2 ms 2688 KB Output is correct
2 Correct 2 ms 2688 KB Output is correct
3 Correct 2 ms 2688 KB Output is correct
4 Correct 2 ms 2688 KB Output is correct
5 Correct 5 ms 2816 KB Output is correct
6 Correct 8 ms 2944 KB Output is correct
7 Correct 15 ms 3200 KB Output is correct
8 Correct 29 ms 3704 KB Output is correct
9 Correct 53 ms 4772 KB Output is correct
10 Correct 5 ms 2816 KB Output is correct
11 Correct 35 ms 4088 KB Output is correct
12 Correct 55 ms 4856 KB Output is correct
13 Correct 53 ms 4856 KB Output is correct
14 Correct 53 ms 4728 KB Output is correct
# Verdict Execution time Memory Grader output
1 Correct 2 ms 2688 KB Output is correct
2 Correct 2 ms 2688 KB Output is correct
3 Correct 2 ms 2688 KB Output is correct
4 Correct 2 ms 2688 KB Output is correct
5 Correct 5 ms 2816 KB Output is correct
6 Correct 8 ms 2944 KB Output is correct
7 Correct 15 ms 3200 KB Output is correct
8 Correct 29 ms 3704 KB Output is correct
9 Correct 53 ms 4772 KB Output is correct
10 Correct 5 ms 2816 KB Output is correct
11 Correct 35 ms 4088 KB Output is correct
12 Correct 55 ms 4856 KB Output is correct
13 Correct 53 ms 4856 KB Output is correct
14 Correct 53 ms 4728 KB Output is correct
15 Incorrect 122 ms 6900 KB Wrong Answer [2]
16 Halted 0 ms 0 KB -
# Verdict Execution time Memory Grader output
1 Correct 2 ms 2688 KB Output is correct
2 Correct 2 ms 2688 KB Output is correct
3 Correct 2 ms 2688 KB Output is correct
4 Correct 2 ms 2688 KB Output is correct
5 Correct 5 ms 2816 KB Output is correct
6 Correct 8 ms 2944 KB Output is correct
7 Correct 15 ms 3200 KB Output is correct
8 Correct 29 ms 3704 KB Output is correct
9 Correct 53 ms 4772 KB Output is correct
10 Correct 5 ms 2816 KB Output is correct
11 Correct 35 ms 4088 KB Output is correct
12 Correct 55 ms 4856 KB Output is correct
13 Correct 53 ms 4856 KB Output is correct
14 Correct 53 ms 4728 KB Output is correct
15 Incorrect 122 ms 6900 KB Wrong Answer [2]
16 Halted 0 ms 0 KB -
# Verdict Execution time Memory Grader output
1 Correct 2 ms 2688 KB Output is correct
2 Correct 2 ms 2688 KB Output is correct
3 Correct 2 ms 2688 KB Output is correct
4 Correct 2 ms 2688 KB Output is correct
5 Correct 5 ms 2816 KB Output is correct
6 Correct 8 ms 2944 KB Output is correct
7 Correct 15 ms 3200 KB Output is correct
8 Correct 29 ms 3704 KB Output is correct
9 Correct 53 ms 4772 KB Output is correct
10 Correct 5 ms 2816 KB Output is correct
11 Correct 35 ms 4088 KB Output is correct
12 Correct 55 ms 4856 KB Output is correct
13 Correct 53 ms 4856 KB Output is correct
14 Correct 53 ms 4728 KB Output is correct
15 Incorrect 122 ms 6900 KB Wrong Answer [2]
16 Halted 0 ms 0 KB -
# Verdict Execution time Memory Grader output
1 Correct 2 ms 2688 KB Output is correct
2 Correct 2 ms 2688 KB Output is correct
3 Correct 2 ms 2688 KB Output is correct
4 Correct 2 ms 2688 KB Output is correct
5 Correct 5 ms 2816 KB Output is correct
6 Correct 8 ms 2944 KB Output is correct
7 Correct 15 ms 3200 KB Output is correct
8 Correct 29 ms 3704 KB Output is correct
9 Correct 53 ms 4772 KB Output is correct
10 Correct 5 ms 2816 KB Output is correct
11 Correct 35 ms 4088 KB Output is correct
12 Correct 55 ms 4856 KB Output is correct
13 Correct 53 ms 4856 KB Output is correct
14 Correct 53 ms 4728 KB Output is correct
15 Incorrect 122 ms 6900 KB Wrong Answer [2]
16 Halted 0 ms 0 KB -
# Verdict Execution time Memory Grader output
1 Correct 2 ms 2688 KB Output is correct
2 Correct 2 ms 2688 KB Output is correct
3 Correct 2 ms 2688 KB Output is correct
4 Correct 2 ms 2688 KB Output is correct
5 Correct 5 ms 2816 KB Output is correct
6 Correct 8 ms 2944 KB Output is correct
7 Correct 15 ms 3200 KB Output is correct
8 Correct 29 ms 3704 KB Output is correct
9 Correct 53 ms 4772 KB Output is correct
10 Correct 5 ms 2816 KB Output is correct
11 Correct 35 ms 4088 KB Output is correct
12 Correct 55 ms 4856 KB Output is correct
13 Correct 53 ms 4856 KB Output is correct
14 Correct 53 ms 4728 KB Output is correct
15 Incorrect 122 ms 6900 KB Wrong Answer [2]
16 Halted 0 ms 0 KB -
# Verdict Execution time Memory Grader output
1 Correct 2 ms 2688 KB Output is correct
2 Correct 2 ms 2688 KB Output is correct
3 Correct 2 ms 2688 KB Output is correct
4 Correct 2 ms 2688 KB Output is correct
5 Correct 5 ms 2816 KB Output is correct
6 Correct 8 ms 2944 KB Output is correct
7 Correct 15 ms 3200 KB Output is correct
8 Correct 29 ms 3704 KB Output is correct
9 Correct 53 ms 4772 KB Output is correct
10 Correct 5 ms 2816 KB Output is correct
11 Correct 35 ms 4088 KB Output is correct
12 Correct 55 ms 4856 KB Output is correct
13 Correct 53 ms 4856 KB Output is correct
14 Correct 53 ms 4728 KB Output is correct
15 Incorrect 122 ms 6900 KB Wrong Answer [2]
16 Halted 0 ms 0 KB -