B. Omkar and Heavenly Tree

原题链接

题解

真的bt啊
由于m没有限制所有测试用例的总和,所以m可以近似看为1e9,也就是说,除了输入以外,不能有任何对m的处理(常数乘上1e9)

考虑菊花图,任意两点之间最多只有一个陌生点,而且 \(m\lt n\) 所以找出那个没有出现过的中间点,作为菊花图的中心
md!!构造题!!

code

#include<bits/stdc++.h>
using namespace std;
int vis[100005]={0};
int main()
{
    int t=1;
    cin>>t;
    while(t--)
    {
        int n,m;
        cin>>n>>m;
        for(int i=1;i<=m;i++)
        {
            int x,y,tem;
            cin>>x>>tem>>y;
            vis[tem]=1;
        }
        int root;
        for(int i=1;i<=n;i++)
        {
            if(!vis[i])
            {
                root=i;
                break;
            }
        }
        for(int i=1;i<=n;i++)
        {
            if(root!=i) cout<<root<<" "<<i<<endl;
            vis[i]=0;
        }
    }
    return 0;
}

posted @ 2024-05-16 20:16  纯粹的  阅读(20)  评论(0)    收藏  举报