卡皮巴拉(c++)

题目描述
有一种卡皮巴拉玩偶,它有头、身体、四肢三个部分,每个部分需要使用不同的材料制作。玩具公司生产了很多批次的卡皮巴拉玩偶,每个批次的玩偶的三个部分都分别有多种款式(每种款式只需使用一种材料)。
现在有`k`批次的卡皮巴拉玩偶,每个批次的玩偶的头、身体和四肢的款式分别有`a`,`b`,`c`种。请你实现两个以结构体 `Capybara` 为参数类型的函数`f1`,`f2`,分别计算出当头、身体、四肢的款式有`a`,`b`,`c`种时,生产本批次玩偶共需要多少种材料,以及本批次玩偶共有多少种款式。
输入描述
一个整数`k`,表示有`k`批次的卡皮巴拉玩偶。(k < 100)
k 行,每行三个整数`a`,`b`,`c`,分别表示每个批次的玩偶的头、身体和四肢的款式数。 
输出描述
k 行,每行两个整数,分别表示每个批次的玩偶共需要多少种材料,以及本批次玩偶共有多少种款式。
输入样例
3
1 2 3
4 5 13
33 4 2 
输出样例
6 6
22 260
39 264
//参考答案
#include <iostream>

using namespace std;

struct Capybara {
    int head;
    int body;
    int limb;
};

int f1(Capybara a){
    return a.head + a.body + a.limb;
}

int f2(Capybara a){
    return a.head * a.body * a.limb;
}

int m[105],n[105];

int main() {
    int k;
    cin >> k;
    for (int i = 1; i <= k; i++) {
        Capybara capybara = Capybara();
        cin >> capybara.head >> capybara.body >> capybara.limb;
        m[i] = f1(capybara);
        n[i] = f2(capybara);
    }
    for (int i = 1; i <= k; i++) {
        cout << m[i] << " " << n[i] << endl;
    }

}

【思维挑战营】卡皮巴拉配对 比赛题目 时间限制:C/C++ 1000MS,其他语言 2000MS 内存限制:C/C++ 256MB,其他语言 512MB 分数:100 描述 李老师计划让卡皮巴拉们两两组队进行课间活动。 但是她发现,卡皮巴拉们很贪玩,每只卡皮巴拉都希望玩够一定的时间,并且当两只卡皮巴拉一起玩耍时,总的玩耍时间会变长! 如果玩耍时间分别为 A 和 B 分钟的两只卡皮巴拉组队,那么它们总共会玩 A+B 分钟。 李老师希望将 M 只卡皮巴拉(M≤10 9 ,M为偶数)分成 M/2 组,他们中玩耍时间最长的一组决定了整个课间的持续时间! 李老师希望通过合理分组,让课间持续的时间尽可能短。 请帮助李老师确定最佳分组下,课间所需的最少时间。 输入描述 输入的第一行包含 N(1≤N≤10 5 ) 接下来的 N 行每行包含两个整数 x 和 y,表示有 x 只玩耍时间为 y 的卡皮巴拉(1≤y≤10 9 )。所有 x 的总和为 M,即卡皮巴拉的总数。 对于 60% 的样例,N(1≤N≤10 4 ) 对于 100% 的样例,N(1≤N≤10 5 ) 输出描述 输出课间所需的最少时间,假设李老师以最佳方式分组。 用例输入 1 3 1 8 2 5 1 2 用例输出 1 10 提示 如果玩耍时间为 8 和 2 分钟的卡皮巴拉组队,玩耍时间为 5 和 5 分钟的卡皮巴拉组队,那么课间为 10 分钟。 任何其他分组方式都会导致某个组的玩耍时间超过 10 分钟. 因此 10 分钟是最优的。 c++代码
03-29
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值