H 题挂求条
  • 板块灌水区
  • 楼主ikunTLE
  • 当前回复5
  • 已保存回复5
  • 发布时间2024/12/13 21:00
  • 上次更新2024/12/14 07:38:18
查看原帖
H 题挂求条
890515
ikunTLE楼主2024/12/13 21:00
#include<bits/stdc++.h>
using namespace std;
#define int long long
int read(){int x=0;char f=1,ch=getchar();while(ch<'0'||ch>'9'){if(ch=='-')f=-1;ch=getchar();}while(ch>='0'&&ch<='9')x=x*10+ch-'0',ch=getchar();return x*f;}
const int N=1e4+10;
struct node{
	string name,s1,s2,s3;
	int id,rk;
	friend bool operator<(const node a,const node b){
		if(a.id!=b.id)
			return a.id<b.id;
		return a.rk<b.rk;
	}
}a[N],b[N];
signed main(){
	ios::sync_with_stdio(false);
	cin.tie(nullptr),cout.tie(nullptr);
	int n,m,t,k;cin>>n>>m>>t>>k;
	for(int i=1;i<=n;++i)
		cin>>a[i].name>>a[i].s1>>a[i].s2>>a[i].s3>>a[i].id>>a[i].rk;
	sort(a+1,a+n+1);
	set<string>s;
	int cnt=0;
	for(int i=1;i<=n&&cnt<k;++i)
		if(s.find(a[i].s1)==s.end()&&s.find(a[i].s2)==s.end()&&s.find(a[i].s3)==s.end()){
			b[++cnt]=a[i];
			s.insert(a[i].s1),s.insert(a[i].s2),s.insert(a[i].s3);
		}
	cout<<cnt<<"\n";
	for(int i=1;i<=cnt;++i)
		cout<<b[i].name<<" "<<b[i].s1<<" "<<b[i].s2<<" "<<b[i].s3<<"\n";
	return 0;
}
2024/12/13 21:00
加载中...