抢红包
没有人没抢过红包吧…… 这里给出NN个人之间互相发红包、抢红包的记录,请你统计一下他们抢红包的收获。
输入格式:
输入第一行给出一个正整数NN(\le 10^4≤104),即参与发红包和抢红包的总人数,则这些人从1到NN编号。随后NN行,第ii行给出编号为ii的人发红包的记录,格式如下:
K\quad N_1\quad P_1\quad \cdots\quad N_K\quad P_KKN1P1⋯NKPK
其中KK(0 \le K \le 200≤K≤20)是发出去的红包个数,N_iNi是抢到红包的人的编号,P_iPi(>0>0)是其抢到的红包金额(以分为单位)。注意:对于同一个人发出的红包,每人最多只能抢1次,不能重复抢。
输出格式:
按照收入金额从高到低的递减顺序输出每个人的编号和收入金额(以元为单位,输出小数点后2位)。每个人的信息占一行,两数字间有1个空格。如果收入金额有并列,则按抢到红包的个数递减输出;如果还有并列,则按个人编号递增输出。
输入样例:
10
3 2 22 10 58 8 125
5 1 345 3 211 5 233 7 13 8 101
1 7 8800
2 1 1000 2 1000
2 4 250 10 320
6 5 11 9 22 8 33 7 44 10 55 4 2
1 3 8800
2 1 23 2 123
1 8 250
4 2 121 4 516 7 112 9 10
输出样例:
1 11.63
2 3.63
8 3.63
3 2.11
7 1.69
6 -1.67
9 -2.18
10 -3.26
5 -3.26
4 -12.32
- 时间限制:400ms
- 内存限制:64MB
- 代码长度限制:16kB
- 判题程序:系统默认
- 作者:陈越
- 单位:浙江大学
题目判定
解题程序
#include<cstdio>
#include<cstring>
#include<cmath>
#include<iomanip>
#include<cstdlib>
#include<iostream>
#include<algorithm>
using namespace std;
#define MAXN 10010
#define INF 0x3f3f3f3f
struct Node
{
int no;//编号
double ans;//金额
int num;//抢到的红包数量
} a[MAXN];
int cmp(Node x,Node y)
{
if(x.ans!=y.ans) return x.ans<y.ans;
else if(x.num!=y.num) return x.num<y.num;
else return x.no>y.no;
}
int main()
{
#ifdef ONLINE_JUDGE
#else
freopen("G:/cbx/read.txt","r",stdin);
//freopen("G:/cbx/out.txt","w",stdout);
#endif
ios::sync_with_stdio(false);
cin.tie(0);
memset(&a,0,sizeof(Node));
int t;
cin>>t;
for(int i=1; i<=t; ++i)
{
a[i].no=i;
int k;
cin>>k;
int n;
double p,sum=0;
for(int j=0; j<k; ++j)
{
cin>>n>>p;
++a[n].num;
//p/=100;
a[n].ans+=p;
sum+=p;
}
a[i].ans-=sum;
}
sort(a,a+t+1,cmp);
for(int i=t; i>=0; --i)
{
if(a[i].no==0) continue;
cout<<setiosflags(ios::fixed);//设置输入浮点形式
cout.precision(2);//设置两位有效数字
cout<<a[i].no<<" "<<a[i].ans/100<<endl;
}
return 0;
}