[Codeforces Round #601 (Div. 2)]C. League of Leesins(模拟)

C. League of Leesins
time limit per test2 seconds
memory limit per test256 megabytes
inputstandard input
outputstandard output

Bob is an avid fan of the video game “League of Leesins”, and today he celebrates as the League of Leesins World Championship comes to an end!

The tournament consisted of n (n≥5) teams around the world. Before the tournament starts, Bob has made a prediction of the rankings of each team, from 1-st to n-th. After the final, he compared the prediction with the actual result and found out that the i-th team according to his prediction ended up at the pi-th position (1≤pi≤n, all pi are unique). In other words, p is a permutation of 1,2,…,n.

As Bob’s favorite League player is the famous “3ga”, he decided to write down every 3 consecutive elements of the permutation p. Formally, Bob created an array q of n−2 triples, where qi=(pi,pi+1,pi+2) for each 1≤i≤n−2. Bob was very proud of his array, so he showed it to his friend Alice.

After learning of Bob’s array, Alice declared that she could retrieve the permutation p even if Bob rearranges the elements of q and the elements within each triple. Of course, Bob did not believe in such magic, so he did just the same as above to see Alice’s respond.

For example, if n=5 and p=[1,4,2,3,5], then the original array q will be [(1,4,2),(4,2,3),(2,3,5)]. Bob can then rearrange the numbers within each triple and the positions of the triples to get [(4,3,2),(2,3,5),(4,1,2)]. Note that [(1,4,2),(4,2,2),(3,3,5)] is not a valid rearrangement of q, as Bob is not allowed to swap numbers belong to different triples.

As Alice’s friend, you know for sure that Alice was just trying to show off, so you decided to save her some face by giving her any permutation p that is consistent with the array q she was given.

Input
The first line contains a single integer n (5≤n≤105) — the size of permutation p.

The i-th of the next n−2 lines contains 3 integers qi,1, qi,2, qi,3 (1≤qi,j≤n) — the elements of the i-th triple of the rearranged (shuffled) array qi, in random order. Remember, that the numbers within each triple can be rearranged and also the positions of the triples can be rearranged.

It is guaranteed that there is at least one permutation p that is consistent with the input.

Output
Print n distinct integers p1,p2,…,pn (1≤pi≤n) such that p is consistent with array q.

If there are multiple answers, print any.

Example
inputCopy
5
4 3 2
2 3 5
4 1 2
outputCopy
1 4 2 3 5

#include<bits/stdc++.h>
using namespace std;
const int maxn=100010;
vector<int > v[maxn];
map<int,int >mp;
int vis[maxn];
int main() {
    int n;
    cin>>n;
    for(int i=1; i<=n-2; i++) {
        int x,y,z;
        cin>>x>>y>>z;
        v[x].push_back(y);
        v[x].push_back(z);
        v[y].push_back(x);
        v[y].push_back(z);
        v[z].push_back(y);
        v[z].push_back(x);
        mp[x]++;
        mp[y]++;
        mp[z]++;
    }
    int flag1;
    for(int i=1; i<=n; i++) {
        if(mp[i]==1) {
            flag1=i;
            break;
        }
    }
    int flag2;
    if(mp[v[flag1][0]]==2) {
        flag2=v[flag1][0];
    } else {
        flag2=v[flag1][1];
    }
 
    vis[flag1]=1;
    vis[flag2]=1;
    cout<<flag1<<" "<<flag2<<" ";
    for(int i=1; i<=n-2; i++) {
        int flag3;
        for(int j=0; j<v[flag1].size(); j++) {
            if(!vis[v[flag1][j]]) {
                flag3=v[flag1][j];
                break;
            }
        }
        vis[flag3]=1;
        cout<<flag3<<" ";
        flag1=flag2;
        flag2=flag3;
    }
    cout<<endl;
    return 0;
}

发布了247 篇原创文章 · 获赞 22 · 访问量 1万+

猜你喜欢

转载自blog.csdn.net/qq_43658924/article/details/103283796