zoukankan      html  css  js  c++  java
  • [蓝桥杯2018决赛]版本分支

    参考博客:https://blog.csdn.net/daixinliangwyx/article/details/90300400(JAVA)

    超内存了。。。。。。(有空指教一哈)

     我提交的题目地址: http://oj.ecustacm.cn/problem.php?id=1400

    #include <iostream>
    #include <cstring> 
    #include <vector>
    #include <queue>
    #include <algorithm>
    
    
    using namespace std;
    
    const int L = 100009;
    vector<int> child[L];
    vector<int> data[L];
    int N,Q; 
    
    vector<int> getChild(int node) {
        for (int i = 0; i < data[node].size(); i++) {
            vector<int> chs = getChild(data[node][i]);
            child[node].insert(child[node].end(), chs.begin(), chs.end());
        }
        child[node].push_back(node);
        return child[node];
    }
    
    int main() {
        
        int p,s;
        while(~scanf("%d%d", &N, &Q)) {
            for (int i = 1; i < N; i++) {
                scanf("%d%d", &p, &s);
                data[p].push_back(s);
                
            }
            
            child[1] = getChild(1);
            
            for (int i = 1; i <= Q; i++) {
                scanf("%d%d", &p, &s);
                vector<int>::iterator it = find(child[p].begin(), child[p].end(), s);
                
                if (it != child[p].end()) {
                    cout << "YES" << endl;
                } else {
                    cout << "NO" << endl;
                }
            }
        
            for (int i = 0; i < L; i++) {
                data[i].clear();
                child[i].clear();
            }
        }
        
        return 0;
    }

    。。。。。。。。。。。。

  • 相关阅读:
    2017.10.12
    2017.10.25
    2017.10.24
    进度条06
    课堂练习(返回一个环状一维整数数组中最大子数组的和)
    团队项目成员和题目
    团队作业--四则运算网页版
    进度条04
    个人作业(最大子数组)
    进度条03
  • 原文地址:https://www.cnblogs.com/hello-dummy/p/12588427.html
Copyright © 2011-2022 走看看