首页
学习
活动
专区
圈层
工具
发布
社区首页 >专栏 >L2-009 抢红包 (25 分)(结构体+自定义排序)

L2-009 抢红包 (25 分)(结构体+自定义排序)

作者头像
Here_SDUT
发布2022-08-08 16:27:20
发布2022-08-08 16:27:20
4970
举报

没有人没抢过红包吧…… 这里给出 N 个人之间互相发红包、抢红包的记录,请你统计一下他们抢红包的收获。

输入格式: 输入第一行给出一个正整数 N(≤10^4),即参与发红包和抢红包的总人数,则这些人从 1 到 N 编号。随后 N 行,第 i 行给出编号为 i 的人发红包的记录,格式如下:

K N_1 P_1 … N_K P_K

其中 K(0≤K≤20)是发出去的红包个数,N_i 是抢到红包的人的编号,P_i(>0)

输出格式: 按照收入金额从高到低的递减顺序输出每个人的编号和收入金额(以元为单位,输出小数点后2位)。每个人的信息占一行,两数字间有1个空格。如果收入金额有并列,则按抢到红包的个数递减输出;如果还有并列,则按个人编号递增输出。

输入样例:

代码语言:javascript
复制
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

输出样例:

代码语言:javascript
复制
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

分析 就是细节题,题目让你干什么就干什么。

代码

代码语言:javascript
复制
//                              _ooOoo_
//                             o8888888o
//                             88" . "88
//                             (| -_- |)
//                              O\ = /O
//                           ____/`---'\____
//                        .   ' \| |// `.
//                         / \||| : |||// \
//                        / _||||| -:- |||||- \
//                         | | \\ - /// | |
//                       | \_| ''\---/'' | |
//                        \ .-\__ `-` ___/-. /
//                    ___`. .' /--.--\ `. . __
//                  ."" '< `.___\_<|>_/___.' >'"".
//                 | | : `- \`.;`\ _ /`;.`/ - ` : | |
//                    \ \ `-. \_ __\ /__ _/ .-` / /
//           ======`-.____`-.___\_____/___.-`____.-'======
//                              `=---='
//
//           .............................................
//                   佛祖保佑     一发AC     永无BUG
#include <bits/stdc++.h>
#define LL long long
using namespace std;
const int maxn = 1e5+10;
const int inf = 0x3f3f3f3f;
const double PI = acos(-1.0);
typedef pair<int,int> PII;
struct node {
    int money, cnt, id;
    const bool operator < (const node &t) const{
        if(money == t.money) {
            if(cnt == t.cnt) return id < t.id;
            return cnt > t.cnt;
        }
        return money > t.money;
    }
}a[maxn];
int main(int argc, char const *argv[]) {
    int n, k, x, y;
    cin >> n;
    for(int i = 1; i <= n; i++) {
        a[i].id = i;
        cin >> k;
        while(k--) {
            cin >> x >> y;
            a[x].cnt++;
            a[x].money += y;
            a[i].money -= y;
        }
    }
    sort(a+1, a+1+n);
    for(int i = 1; i <= n; i++) printf("%d %.2lf\n",a[i].id, a[i].money*1.0/100);
    return 0;
}
本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2021-3-19 1,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档