社区讨论

改了,仍70,求

P1786帮贡排序参与者 2已保存回复 2

讨论操作

快速查看讨论及其快照的属性,并进行相关操作。

当前回复
2 条
当前快照
1 份
快照标识符
@m13o6h4e
此快照首次捕获于
2024/09/15 22:26
去年
此快照最后确认于
2025/11/04 21:09
4 个月前
查看原帖
CPP
#include <iostream>
#include <cstring>
#include <algorithm>
using namespace std;
int n;
struct ren{
	string name,pos;
	int lev,exp,posi;
	long long bang;
};
ren a[112],b[4];
bool cmp(ren a,ren b)
{
	if(a.bang!=b.bang) return a.bang>b.bang;
	if(a.lev!=b.lev) return a.lev>b.lev;
	return a.exp>b.exp;
}
bool cmp2(ren a,ren b)
{
	if(a.posi!=b.posi) return a.posi>b.posi;
	if(a.lev!=b.lev) return a.lev>b.lev;
	return a.exp>b.exp;
}
int main()
{
	cin>>n;n-=3;
	for(int i=1;i<=3;i++)
	cin>>b[i].name>>b[i].pos>>b[i].bang>>b[i].lev;
	b[2].exp=2;b[3].exp=1;
	sort(b+2,b+4,cmp2);
	for(int i=1;i<=n;i++)
	{
		cin>>a[i].name>>a[i].pos>>a[i].bang>>a[i].lev;
		a[i].exp=n+1-i;
	}
	for(int i=1;i<=3;i++)
	cout<<b[i].name<<' '<<b[i].pos<<' '<<b[i].lev<<endl;
	if(n==0) return 0;
	sort(a+1,a+n+1,cmp);
	for(int i=1;i<=n;i++)
	{
		if(i==1||i==2) {
			a[i].pos="HuFa";a[i].posi=5;
		}
		if(i>=3&&i<=6) {
			a[i].pos="ZhangLao";a[i].posi=4;
		}
		if(i>=7&&i<=13) {
			a[i].pos="TangZhu";a[i].posi=3;
		}
		if(i>=14&&i<=38) {
			a[i].pos="JingYing";a[i].posi=2;
		}
		if(i>=39) {
			a[i].pos="BangZhong";a[i].posi=1;
		}
	}
	sort(a+1,a+n+1,cmp2);
	for(int i=1;i<=n;i++)
	cout<<a[i].name<<' '<<a[i].pos<<' '<<a[i].lev<<endl;
	return 0;
}

回复

2 条回复,欢迎继续交流。

正在加载回复...