Submission #558083

#TimeUsernameProblemLanguageResultExecution timeMemory
558083status_codingNewspapers (CEOI21_newspapers)C++14
4 / 100
3 ms2772 KiB
#include <bits/stdc++.h>

using namespace std;

int n,m;

vector<int> v[100005];

int dp[100005];

void dfs(int p, int par)
{
    dp[p] = 1;
    bool can1=true, can=true;

    for(int it : v[p])
    {
        if(it == par)
            continue;

        if((int)v[it].size() == 1)
            continue;

        dfs(it, p);

        if(dp[it] == -1)
        {
            dp[p] = -1;
            return;
        }

        dp[p] = 2;

        if(dp[it] == 1 && can1)
            can1 = false;
        else
        {
            if(can)
                can = false;
            else
            {
                dp[p] = -1;
                return;
            }
        }
    }
}

int main()
{
    cin>>n>>m;

    if(m > n-1)
    {
        cout<<"NO";
        return 0;
    }

    for(int i=1;i<n;i++)
    {
        int x, y;
        cin>>x>>y;

        v[x].push_back(y);
        v[y].push_back(x);
    }

    for(int i=1;i<=n;i++)
    {
        dfs(i, 0);

        if(dp[i] != -1)
        {
            cout<<"YES\n";
            cout<<"1 1";
            return 0;
        }
    }

    cout<<"NO";
    return 0;
}
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...