SDUSTOJ1807 Problem G: 开个餐馆算算账

Description

小明创业了!他开了一家餐馆,每天客人还挺多的。每天下班后,他都要算算今天总共收入多少钱,但是手工算太麻烦了,所以他来向你求助了。

Input

第1行N>0,表示餐馆提供N个菜品。
.
之后N行,每行包括2部分:菜名(不含空白符)及每份菜品的价格。
.
接着是M>0,表示今天接待的客人数。
.
每个客人的输入份三部分,第1行是客人的姓名(不含空白符),第2行是客人点的菜品的种类数K,之后K行是客人点的菜品名及份数。

Output

第一行输出Guest Price。
.
之后按照客人姓名从小到大的顺序(没有重名的顾客),依次输出每个客人消费了多少钱,消费额保留2位小数。
.
输出时,姓名左对齐,宽度为所有客人姓名的最大长度加1。

Sample Input

10
Yu-Shiang-Shredded-Pork 20
sweet-sour-Shredded-potato 15
Pie 0.50
Steamed-Rice 1.50
Tomato-and-Egg-Soup 17
Spareribs-with-brown-sauce 55
Sauteed-Sliced-Lamb-with-Scallion 60
Stir-fried-bean-sprouts 14
Moo-Shu-Pork 18
Deep-Fried-Dough-Sticks 2.50
3
Zhangsan
4
Yu-Shiang-Shredded-Pork 1
sweet-sour-Shredded-potato 1
Pie 3
Steamed-Rice 1
LiSi
2
Moo-Shu-Pork 1
Deep-Fried-Dough-Sticks 4
WangWu
3
Tomato-and-Egg-Soup 1
Spareribs-with-brown-sauce 1
Sauteed-Sliced-Lamb-with-Scallion 1

Sample Output

Guest Price
LiSi 28.00
WangWu 132.00
Zhangsan 38.00

HINT

Append Code

标程

#include <bits/stdc++.h>
using namespace std;
 
map<string, double> mp;
 
 
struct po{
    string name;
    double price;
}pos[1000];
 
bool cmp(struct po a, struct po b) {return a.name < b.name;}
 
int main() {
    int num;
    cin >> num;
    while(num--) {
        string s;
        double d;
        cin >> s >> d;
        mp[s] = d;
    }
    int guest;
    cin >> guest;
    for(int i = 0; i < guest; i++) {
        string s;
        cin >> s;
        pos[i].name = s;
        pos[i].price = 0.0;
        int wish;
        cin >> wish;
        while(wish--) {
            string ss;
            int nn;
            cin >> ss >> nn;
            pos[i].price += mp[ss]*(double)nn;
        }
    }
    sort(pos, pos+guest, cmp);
    int len = 0;
    for(int i = 0; i < guest; i++) {
        int xx = pos[i].name.length();
        len = max(len, xx);
    }
    cout<<setiosflags(ios::left)<<setw(len+1)<<"Guest"<<"Price"<<endl;
    for(int i = 0; i < guest; i++) {
        cout << setiosflags(ios::left) << setw(len+1) << pos[i].name << fixed << setprecision(2) << pos[i].price << endl;
    }
    return 0;
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值