程序设计与算法(三)第03周测验002:Big & Base 封闭类问题

程序设计与算法(三)第03周测验002:Big & Base 封闭类问题

本文是中国大学MOOC,北京大学程序设计与算法(三)C++面向对象程序设计第三周测验。本课程学习的github仓库欢迎Fork

  • 总时间限制:

    1000ms

  • 内存限制:

    65536kB

  • 描述

    程序填空,输出指定结果

    #include <iostream>
    #include <string>
    using namespace std;
    class Base {
    public:
    	int k;
    	Base(int n):k(n) { }
    };
    class Big
    {
    public:
    	int v;
    	Base b;
    // 在此处补充你的代码
    };
    int main()
    {
    	int n;
    	while(cin >>n) {
    		Big a1(n);
    		Big a2 = a1;
    		cout << a1.v << "," << a1.b.k << endl;
    		cout << a2.v << "," << a2.b.k << endl;
    	}
    }
    
  • 输入

    多组数据,每组一行,是一个整数

  • 输出

    对每组数据,输出两行,每行把输入的整数打印两遍

  • 样例输入

    3
    4
    
  • 样例输出

    3,3
    3,3
    4,4
    4,4
    

    老规矩,先看主函数:

    int main()
    {
    	int n;
    	while(cin >>n) {
    		Big a1(n);		//构造函数,初始化a1
    		Big a2 = a1;	//复制构造函数,复制a1
    		cout << a1.v << "," << a1.b.k << endl;
    		cout << a2.v << "," << a2.b.k << endl;
    	}
    }
    

    再看类函数:

    class Base {
    public:
    	int k;
    	Base(int n):k(n) { }
    };
    
    class Big	//有成员变量的类叫封闭类
    {
    public:
    	int v;
    	Base b;	//成员对象
    // 在此处补充你的代码
    };
    

    注意,这是一个封闭类,课程的PPT有讲到:

    任何生成封闭类对象的语句,都要使得编译器明白,对象中的成员对象,是如何初始化的。完成这一任务的方法是通过封闭类的构造函数的初始化列表,成员对象初始化列表中的参数可以是任意复杂的表达式,可以包括函数,变量,只要表达式中的函数或变量有定义就行。

    如果题目不懂,不妨把课程对应部分再看一遍。慢慢来,比较快。不要心浮气躁。

    所以我们需要使用初始化列表进行封闭类的初始化:

    class Big
    {
    public:
        int v;
        Base b;
    // 在此处补充你的代码
        Big(int n):v(n),b(n){}	//初始化列表
    };
    

    提交,通过。记得下载通过码。

  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

陈沧夜

打个赏,让我买瓶可乐喝呗~

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

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

打赏作者

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

抵扣说明:

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

余额充值