제출 #528665

#제출 시각아이디문제언어결과실행 시간메모리
528665happypotatoArranging Shoes (IOI19_shoes)C++17
25 / 100
23 ms1860 KiB
#include "shoes.h"
#include <bits/stdc++.h>
#define ll long long
using namespace std;
const int mxN = 2e5 + 1;
int seg[4 * mxN];
int n;
void update(int tar, int l = 1, int r = n, int idx = 1) {
    if (l == r) {
        seg[idx] ^= 1;
        return;
    }
    int mid = (l + r) >> 1;
    if (tar <= mid) update(tar, l, mid, (idx << 1));
    else update(tar, mid + 1, r, (idx << 1) + 1);
    seg[idx] = seg[(idx << 1)] + seg[(idx << 1) + 1];
    return;
}
int query(int tarl, int tarr, int l = 1, int r = n, int idx = 1) {
    if (tarl > tarr) return 0;
    if (tarl <= l && r <= tarr) return seg[idx];
    else if (tarr < l || r < tarl) return 0;
    int mid = (l + r) >> 1;
    return query(tarl, min(tarr, mid), l, mid, (idx << 1)) + query(max(tarl, mid + 1), tarr, mid + 1, r, (idx << 1) + 1);
}
long long st1(vector<int> &s) {
    if (s[0] == -1 && s[1] == 1) return 0;
    else if (s[0] == 1 && s[1] == -1) return 1;
    else {
        while (true) continue;
    }
}
long long st2(vector<int> &s) {
    return -1;
}
long long st3(vector<int> &s) {
    return -1;
}
long long st4(vector<int> &s) {
    long long n = s.size() / 2;
    n = (n - 1) * n / 2;
    return n;
}
long long count_swaps(vector<int> s) {
    n = s.size();
    if (n / 2 == 1) return st1(s);
    // else if (n / 2 <= 8) return st2(s);
    // bool ckst3 = true;
    // for (int i = 1; i < n; i++) {
    //     if (abs(s[0]) != abs(s[i])) {
    //         ckst3 = false;
    //         break;
    //     }
    // }
    // if (ckst3) return st3(s);
    bool ckst4 = true;
    for (int i = 0; i < n / 2; i++) {
        if (s[i] + s[i + n] != 0 || s[i] > 0) {
            ckst4 = false;
            break;
        }
    }
    if (ckst4) return st4(s);
}

컴파일 시 표준 에러 (stderr) 메시지

shoes.cpp: In function 'long long int count_swaps(std::vector<int>)':
shoes.cpp:64:1: warning: control reaches end of non-void function [-Wreturn-type]
   64 | }
      | ^
#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...