OpenJudge | 发票统计

总时间限制: 1000ms 内存限制: 65536kB

描述

有一个小型的报账系统,它有如下功能:
(1)统计每个人所报发票的总钱数
(2)统计每类发票的总钱数
将此系统简化为如下:假设发票类别共有A、B、C三种;一共有三个人,ID分别为1、2、3。

输入

系统输入包含三行,每行第一个数为人员ID(整型,1或2或3),第二个数为发票总张数(张数不超过100),之后是多个发票类别(字符型,A或B或C)和相应发票金额(单进度浮点型,不超过1000.0)。

输出

输出包含六行,前三行为每人(按ID由小到大输出)所报发票总钱数(保留两位小数),后三行为每类发票的总钱数(保留两位小数)。

样例输入

1 5 A 1.0 A 2.0 C 1.0 B 1.0 C 1
3 3 B 1 C 2 C 1
2 4 B 1 A 1 C 1 A 1

样例输出

1 6.00
2 4.00
3 4.00
A 5.00
B 3.00
C 6.00

Code

#include <bits/stdc++.h>
using namespace std;

int main() {
	ios::sync_with_stdio(false);
	cin.tie(0),cout.tie(0);
	array<array<double, 3>, 3> a {};	// 1: array<double, 3>	array<double, 3>: A B C
	int id, n;
	char typ;
	double price;
	for(int i = 0; i < 3; i++) {
		cin >> id >> n;
		for(int j = 0; j < n; j++) {
			cin >> typ >> price;
			switch (typ) {
			case 'A':
				a[id-1][0] += price; break;
			case 'B':
				a[id-1][1] += price; break;
			case 'C':
				a[id-1][2] += price; break;
			}
		}
	}
	for(int i = 0; i < 3; i++) {
		double sum = 0;
		for(int j = 0; j < 3; j++) sum += a[i][j];
		cout << setprecision(2) << fixed << i+1 << " " << sum << endl;
	}
	for(int i = 0; i < 3; i++) {
		double sum = 0;
		for(int j = 0; j < 3; j++) sum += a[j][i];
		cout << setprecision(2) << fixed << (char)('A'+i) << " " << sum << endl;
	}
}
  • 4
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Mryan2005

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值