卡皮巴拉之成员函数

题目描述

本题的题目要求与上题卡皮巴拉相同,但要求你将函数f1,f2实现为结构体Capybara成员函数,分别计算出当头、身体、四肢的款式有a,b,c种时,生产本批次玩偶共需要多少种材料,以及本批次玩偶共有多少种款式。

关于成员函数:有关成员函数的更多知识,我们会在的学习中进行详细讲解。现在我们只需要知道,成员函数是定义在类中的函数。我们不需要把这个结构体本身作为参数传入这个成员函数,但是在它的函数体中,我们可以直接调用此结构体中的其他数据成员(比如在下例中,函数foo中调用了数据成员headtail)。 一个例子如下:

struct Capybara {
    
    //三个数据成员
    int head;
    int body;
    int limb;
    
    //成员函数f1
    int foo() {
        return 2 * head + body;
    }
   
};

那么,当我们创建一个结构体Capybara对象a,并将a.head赋值为1,a.body赋值为2,后,调用a.foo()的返回结果为4。

通过对比本题与上题的不同,希望你可以对成员函数有些初步的认识。

输入描述

一个整数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() const{
        return head + body + limb;
    }

    int f2() const{
        return head * body * 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] = capybara.f1();
        n[i] = capybara.f2();
    }
    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、付费专栏及课程。

余额充值