답안 #852554

# 제출 시각 아이디 문제 언어 결과 실행 시간 메모리
852554 2023-09-22T05:09:09 Z abcvuitunggio Regions (IOI09_regions) C++17
1 / 100
6469 ms 131072 KB
#include <bits/stdc++.h>
#define int long long
using namespace std;
const int sz=55;
int n,R,q,r1,r2,cnt[200001][sz+1],c[25001][sz+1],c2[25001][sz+1],r[200001],p[200001],tin[200001],tout[200001],t,C[25001],pos[25001];
vector <int> ke[200001],ve[25001],V;
void dfs(int u){
    tin[u]=++t;
    ve[r[u]].push_back(t);
    if (pos[r[u]]<=sz)
        cnt[u][pos[r[u]]]++;
    for (int v:ke[u]){
        for (int i=1;i<=sz;i++)
            cnt[v][i]+=cnt[u][i];
        dfs(v);
    }
    for (int i=1;i<=sz;i++)
        c[r[u]][i]+=cnt[u][i];
    tout[u]=++t;
    ve[r[u]].push_back(-t);
}
void dfs2(int u){
    if (pos[r[u]]<=sz)
        cnt[u][pos[r[u]]]++;
    for (int v:ke[u]){
        dfs2(v);
        for (int i=1;i<=sz;i++)
            cnt[u][i]+=cnt[v][i];
    }
    for (int i=1;i<=sz;i++)
        c2[r[u]][i]+=cnt[u][i];
    tout[u]=++t;
    ve[r[u]].push_back(-t);
}
int32_t main(){
    ios_base::sync_with_stdio(NULL);cin.tie(nullptr);
    cin >> n >> R >> q;
    for (int i=1;i<=n;i++){
        if (i>1){
            cin >> p[i];
            ke[p[i]].push_back(i);
        }
        cin >> r[i];
        C[r[i]]++;
    }
    for (int i=1;i<=R;i++)
        V.push_back(r[i]);
    sort(V.begin(),V.end(),[](int i, int j){return C[i]<C[j];});
    for (int i=0;i<V.size();i++)
        pos[V[i]]=i+1;
    dfs(1);
    memset(cnt,0,sizeof(cnt));
    dfs2(1);
    while (q--){
        cin >> r1 >> r2;
        if (pos[r1]<=sz){
            cout << c[r2][pos[r1]] << endl;
            continue;
        }
        if (pos[r2]<=sz){
            cout << c2[r1][pos[r2]] << endl;
            continue;
        }
        int j=0,cnt=0,res=0;
        for (int i=0;i<ve[r2].size();i++){
            while (j<ve[r1].size()){
                if (abs(ve[r1][j])>abs(ve[r2][i]))
                    break;
                cnt+=(ve[r1][j]>0)-(ve[r1][j]<0);
                j++;
            }
            if (ve[r2][i]>0)
                res+=cnt;
        }
        cout << res << endl;
    }
}

Compilation message

regions.cpp: In function 'int32_t main()':
regions.cpp:49:19: warning: comparison of integer expressions of different signedness: 'long long int' and 'std::vector<long long int>::size_type' {aka 'long unsigned int'} [-Wsign-compare]
   49 |     for (int i=0;i<V.size();i++)
      |                  ~^~~~~~~~~
regions.cpp:65:23: warning: comparison of integer expressions of different signedness: 'long long int' and 'std::vector<long long int>::size_type' {aka 'long unsigned int'} [-Wsign-compare]
   65 |         for (int i=0;i<ve[r2].size();i++){
      |                      ~^~~~~~~~~~~~~~
regions.cpp:66:21: warning: comparison of integer expressions of different signedness: 'long long int' and 'std::vector<long long int>::size_type' {aka 'long unsigned int'} [-Wsign-compare]
   66 |             while (j<ve[r1].size()){
      |                    ~^~~~~~~~~~~~~~
# 결과 실행 시간 메모리 Grader output
1 Correct 15 ms 103512 KB Output is correct
2 Incorrect 12 ms 103388 KB Output isn't correct
3 Incorrect 13 ms 103512 KB Output isn't correct
4 Incorrect 13 ms 103512 KB Output isn't correct
5 Incorrect 15 ms 103512 KB Output isn't correct
6 Incorrect 21 ms 102940 KB Output isn't correct
7 Incorrect 26 ms 102744 KB Output isn't correct
8 Incorrect 26 ms 102744 KB Output isn't correct
9 Incorrect 38 ms 103256 KB Output isn't correct
10 Incorrect 56 ms 104280 KB Output isn't correct
11 Incorrect 68 ms 103808 KB Output isn't correct
12 Incorrect 78 ms 105384 KB Output isn't correct
13 Incorrect 94 ms 103948 KB Output isn't correct
14 Incorrect 101 ms 104768 KB Output isn't correct
15 Incorrect 141 ms 109260 KB Output isn't correct
# 결과 실행 시간 메모리 Grader output
1 Incorrect 3375 ms 109012 KB Output isn't correct
2 Incorrect 6296 ms 107156 KB Output isn't correct
3 Incorrect 6469 ms 112900 KB Output isn't correct
4 Incorrect 168 ms 106572 KB Output isn't correct
5 Incorrect 224 ms 111996 KB Output isn't correct
6 Incorrect 666 ms 112936 KB Output isn't correct
7 Incorrect 867 ms 115972 KB Output isn't correct
8 Incorrect 700 ms 124116 KB Output isn't correct
9 Incorrect 1213 ms 125900 KB Output isn't correct
10 Runtime error 96 ms 131072 KB Execution killed with signal 9
11 Runtime error 126 ms 131072 KB Execution killed with signal 9
12 Incorrect 1482 ms 131028 KB Output isn't correct
13 Runtime error 151 ms 131072 KB Execution killed with signal 9
14 Runtime error 184 ms 131072 KB Execution killed with signal 9
15 Runtime error 121 ms 131072 KB Execution killed with signal 9
16 Runtime error 68 ms 131072 KB Execution killed with signal 9
17 Runtime error 67 ms 131072 KB Execution killed with signal 9