Recently personal training sessions have finished in the Berland State University Olympiad Programmer Training Centre. By the results of these training sessions teams are composed for the oncoming team contest season. Each team consists of three people. All the students of the Centre possess numbers from 1 to 3n, and all the teams possess numbers from 1 to n. The splitting of students into teams is performed in the following manner: while there are people who are not part of a team, a person with the best total score is chosen among them (the captain of a new team), this person chooses for himself two teammates from those who is left according to his list of priorities. The list of every person's priorities is represented as a permutation from the rest of 3n - 1 students who attend the centre, besides himself.
You are given the results of personal training sessions which are a permutation of numbers from 1 to 3n, where the i-th number is the number of student who has won the i-th place. No two students share a place. You are also given the arrangement of the already formed teams in the order in which they has been created. Your task is to determine the list of priorities for the student number k. If there are several priority lists, choose the lexicographically minimal one.
InputThe first line contains an integer n (1 ≤ n ≤ 105) which is the number of resulting teams. The second line contains 3n space-separated integers from 1 to 3n which are the results of personal training sessions. It is guaranteed that every student appears in the results exactly once.
Then follow n lines each containing three integers from 1 to 3n — each line describes the members of a given team. The members of one team can be listed in any order, but the teams themselves are listed in the order in which they were created. It is guaranteed that the arrangement is correct, that is that every student is a member of exactly one team and those teams could really be created from the given results using the method described above.
The last line contains number k (1 ≤ k ≤ 3n) which is the number of a student for who the list of priorities should be found.
Print 3n - 1 numbers — the lexicographically smallest list of priorities for the student number k.
The lexicographical comparison is performed by the standard < operator in modern programming languages. The list a is lexicographically less that the list b if exists such an i (1 ≤ i ≤ 3n), that ai < bi, and for any j (1 ≤ j < i) aj = bj. Note, that the list 1 9 10 is lexicographically less than the list 1 10 9. That is, the comparison of lists is different from the comparison of lines.
3 5 4 1 2 6 3 7 8 9 5 6 2 9 3 4 1 7 8 4
2 3 5 6 9 1 7 8
3 5 4 1 2 6 3 7 8 9 5 6 2 9 3 4 1 7 8 8
1 2 3 4 5 6 7 9
2 4 1 3 2 5 6 4 6 5 1 2 3 4
5 6 1 2 3
先找出队长,,如果k不是队长,输出1 - n 否则,找k的队员。。
#include <iostream>
#include <cstdio>
#include <stdio.h>
#include <cstdlib>
#include <cmath>
#include <algorithm>
#include <climits>
#include <cstring>
#include <string>
#include <set>
#include <map>
#include <queue>
#include <stack>
#include <vector>
#include <list>
#define rep(i,m,n) for(i=m;i<=n;i++)
#define rsp(it,s) for(set<int>::iterator it=s.begin();it!=s.end();it++)
const int inf_int = 2e9;
const long long inf_ll = 2e18;
#define inf_add 0x3f3f3f3f
#define mod 1000000007
#define vi vector<int>
#define pb push_back
#define mp make_pair
#define fi first
#define se second
#define pi 3.1415927
#define pii pair<int,int>
#define Lson L, mid, rt<<1
#define Rson mid+1, R, rt<<1|1
const int maxn=5e2+10;
using namespace std;
typedef long long ll;
typedef unsigned long long ull;
inline int read(){int ra,fh;char rx;rx=getchar(),ra=0,fh=1;
while((rx<'0'||rx>'9')&&rx!='-')rx=getchar();if(rx=='-')
fh=-1,rx=getchar();while(rx>='0'&&rx<='9')ra*=10,ra+=rx-48,
rx=getchar();return ra*fh;}
//#pragma comment(linker, "/STACK:102400000,102400000")
ll gcd(ll p,ll q){return q==0?p:gcd(q,p%q);}
ll qpow(ll p,ll q){ll f=1;while(q){if(q&1)f=f*p;p=p*p;q>>=1;}return f;}
int n,k;
int flag[300005];
int flag1[300005];
int a[1000000];
int head[300005] ;
queue<int> aa;
int team1[100005][3];
int main()
{
ios::sync_with_stdio(false);
cin >> n;
for(int i=1;i<=3*n;i++)
{
cin >> a[i];
aa.push(a[i]);
}
for(int i=1;i<=n;i++)
{
cin>>team1[i][0]>>team1[i][1]>>team1[i][2];
}
cin >> k;
int tt=0;
for(int i=1;i<=n;i++)
{
head[i] = aa.front();
if(head[i]==k)
{
tt = i;
break;
}
aa.pop();
flag1[team1[i][1]]=1;
flag1[team1[i][2]]=1;
if(!aa.empty())
{
while(flag1[aa.front()]==1)
{
aa.pop();
if(aa.empty())
break;
}
}
}
if(tt==0)
{
for(int i=1;i<=n*3;i++)
{
if(i!=k)
cout<<i<<" ";
}
cout<<endl;
return 0;
}
for(int i=1;i<=tt;i++)
{
flag[team1[i][0]]++;
flag[team1[i][1]]++;
flag[team1[i][2]]++;
}
int yy = 0;
for(int i=0;i<3;i++)
{
if(team1[tt][i]!=k)
{
if(team1[tt][i]>yy)
{
yy = team1[tt][i];
}
}
}
for(int i=1;i<=yy;i++)
{
if(flag[i]&&i!=k)
{
flag[i]=2;
cout<<i<<" ";
}
}
for(int i=1;i<=n*3;i++)
{
if(flag[i]!=2&&i!=k)
{
cout<<i<<" ";
}
}
cout<<endl;
return 0;
}