답안 #736516

# 제출 시각 아이디 문제 언어 결과 실행 시간 메모리
736516 2023-05-05T20:56:14 Z vjudge1 코알라 (APIO17_koala) C++11
24 / 100
83 ms 440 KB
#include "koala.h"

#include <bits/stdc++.h>
using namespace std;

int minValue(int N, int W) {
        // TODO: Implement Subtask 1 solution here.
        // You may leave this function unmodified if you are not attempting this
        // subtask.
        int A[N], B[N];
        for (int i = 0; i < N; i++) A[i] = i == 0;
        playRound(A, B);
        for (int i = 0; i < N; i++) {
                if (B[i] <= A[i]) return i;
        }
        return -1;
}

int maxValue(int N, int W) {
        // TODO: Implement Subtask 2 solution here.
        // You may leave this function unmodified if you are not attempting this
        // subtask.
        vector<int> candidates(N);
        iota(candidates.begin(), candidates.end(), 0);
        while (candidates.size() != 1) {
                int cnt = W / candidates.size();
                int A[N], B[N];
                for (int i = 0; i < N; i++) A[i] = 0;
                for (int i : candidates) A[i] = cnt;
                playRound(A, B);
                vector<int> nc;
                for (int i : candidates) {
                        if (B[i] > A[i]) nc.emplace_back(i);
                }
                candidates = nc;
        }
        return candidates[0];
}

int greaterValue(int N, int W) {
        int l = 0, r = 50;
        int A[N], B[N];
        for (int i = 0; i < N; i++) A[i] = 0;
        while (l <= r) {
                int mid = l + r >> 1;
                A[0] = A[1] = mid;
                playRound(A, B);
                if (B[0] > A[0] && B[1] > A[1]) {
                        l = mid + 1;
                } else if (B[0] <= A[0] && B[1] <= A[1]) {
                        r = mid - 1;
                } else {
                        return B[1] > A[1];
                }
        }
        // TODO: Implement Subtask 3 solution here.
        // You may leave this function unmodified if you are not attempting this
        // subtask.
        return 0;
}

void allValues(int N, int W, int *P) {
        if (W == 2 * N) {
                // TODO: Implement Subtask 4 solution here.
                // You may leave this block unmodified if you are not attempting this
                // subtask.
        } else {
                // TODO: Implement Subtask 5 solution here.
                // You may leave this block unmodified if you are not attempting this
                // subtask.
        }
}

Compilation message

koala.cpp: In function 'int greaterValue(int, int)':
koala.cpp:45:29: warning: suggest parentheses around '+' inside '>>' [-Wparentheses]
   45 |                 int mid = l + r >> 1;
      |                           ~~^~~
# 결과 실행 시간 메모리 Grader output
1 Correct 4 ms 208 KB Output is correct
2 Correct 4 ms 208 KB Output is correct
3 Correct 4 ms 208 KB Output is correct
4 Correct 3 ms 236 KB Output is correct
# 결과 실행 시간 메모리 Grader output
1 Correct 13 ms 208 KB Output is correct
2 Correct 12 ms 316 KB Output is correct
3 Correct 11 ms 316 KB Output is correct
4 Correct 14 ms 320 KB Output is correct
# 결과 실행 시간 메모리 Grader output
1 Partially correct 80 ms 320 KB Output is partially correct
2 Partially correct 78 ms 436 KB Output is partially correct
3 Partially correct 77 ms 320 KB Output is partially correct
4 Partially correct 83 ms 336 KB Output is partially correct
5 Partially correct 74 ms 328 KB Output is partially correct
6 Partially correct 79 ms 320 KB Output is partially correct
7 Partially correct 82 ms 320 KB Output is partially correct
8 Partially correct 74 ms 316 KB Output is partially correct
9 Partially correct 78 ms 440 KB Output is partially correct
10 Partially correct 81 ms 308 KB Output is partially correct
# 결과 실행 시간 메모리 Grader output
1 Incorrect 1 ms 208 KB Output isn't correct
2 Halted 0 ms 0 KB -
# 결과 실행 시간 메모리 Grader output
1 Incorrect 0 ms 208 KB Output isn't correct
2 Halted 0 ms 0 KB -