【id:62】【20分】E. 日期时间合并输出(友元函数)

本文描述了一个C++编程问题,涉及创建两个类(Date和Time)来存储日期和时间,并定义一个全局函数display作为这两个类的友元,用于格式化输出日期和时间。输入包括多组日期和时间数据,程序需按照指定格式输出。代码示例中展示了如何使用构造函数初始化对象,以及利用<iomanip>库设置输出格式。

时间限制
1s
内存限制
128MB
题目描述

已知日期类Date,有属性:年、月、日,其他成员函数根据需要自行编写,注意该类没有输出的成员函数
已知时间类Time,有属性:时、分、秒,其他成员函数根据需要自行编写,注意该类没有输出的成员函数
现在编写一个全局函数把时间和日期的对象合并起来一起输出,
函数原型为:void display(const Date &d, const Time &t)
函数输出要求为:
1、时分秒输出长度固定2位,不足2位补0
2、年份输出长度固定为4位,月和日的输出长度固定2位,不足2位补0
例如2017年3月3日19时5分18秒
则输出为:2017-03-03 19:05:18

程序要求
1、把函数display作为时间类、日期类的友元
2、分别创建一个日期对象和时间对象,保存日期的输入和时间的输入
3、调用display函数实现日期和时间的合并输出

输入

第一行输入t表示有t组示例

接着一行输入三个整数,表示年月日

再接着一行输入三个整数,表示时分秒

依次输入t组示例

输出

每行输出一个日期和时间合并输出结果

输出t行

#include <iostream>
#include <iomanip> // 用于设置输出格式
using namespace std;

// 前向声明,让Date类和Time类知道display函数的存在
void display(const class Date &d, const class Time &t);

class Date
{
private:
    int year, month, day;
public:
    // 构造函数
    Date(int y, int m, int d)
    {
        year = y;
        month = m;
        day = d;
    }
    // 友元函数,可以访问Date类的私有成员
    friend void display(const Date &d, const Time &t);
};

class Time
{
private:
    int hour, minute, second;
public:
    // 构造函数
    Time(int h, int m, int s)
    {
        hour = h;
        minute = m;
        second = s;
    }
    // 友元函数,可以访问Time类的私有成员
    friend void display(const Date &d, const Time &t);
};

// 全局函数,可以访问Date和Time类的私有成员
void display(const Date &d, const Time &t)
{
    // 设置输出格式,不足2位的数字用0填充
    cout << setfill('0');
    // 输出年份、月份、日期
    cout << setw(4) << d.year << "-" << setw(2) << d.month << "-" << setw(2) << d.day << " ";
    // 输出小时、分钟、秒钟
    cout << setw(2) << t.hour << ":" << setw(2) << t.minute << ":" << setw(2) << t.second << endl;
}

int main()
{
    int t;
    cin >> t;
    while (t--)
    {
        // 输入日期和时间
        int y, m, d, h, mi, s;
        cin >> y >> m >> d >> h >> mi >> s;
        // 创建日期对象和时间对象
        Date date(y, m, d);
        Time time(h, mi, s);
        // 输出日期和时间
        display(date, time);
    }
    return 0;
}

id:449】【33】C. 带头结点的单链表的构造合并 时间限制 1s 内存限制 128MB 题目描述 定义一个带头结点的单链表类,并根据输出为这个类添加适当的成员函数,使得主程序能正常运行。 提示: 需要定义结点类LNode单链表类LinkList 以下是关于linkList类的建议 Ø数据成员 v至少需要一个LNode 的指针成员head, v可增加一个整型变量num来存储链表中的结点数目 v如果想方便在链表最后插入新节点,可以增加一个指针tail来指向表尾 Ø 构造函数 v默认构造函数(构造一个只有的头结点的空链表) v有参构造函数(构造有n个结点的单链表,结点数据可以从键盘输入,也可以来自于一个数组,具体由参数来决定) v拷贝构造函数(有指针成员,根据应用需求如果有拷贝发生,一定要定义拷贝构造) Ø析构函数 v 一定要定义析构函数(有指针成员) Ø其他成员函数 v 显示函数display v 合并函数ListMerge(l2)把l2 中的结点连接到后面,保持l2 不变 v 追加函数ListAppend(d)在链表后增加一个结点元素为d Ø 以上所有函数都涉及到对LNode的数据进行访问修改,为操作方便,需要声明友元类 v 把LinkList声明为LNode的友元 输入 单链表的结点数目及结点的元素值,逗号输出 根据主函数进行析 IO模式 本题IO模式为标准输入/输出(Standard IO),你需要从标准输入流中读入数据,并将答案输出至标准输出流中。 样例查看模式 正常显示 查看格式 输入样例1 <-复制 5 1 2 3 4 5 4 输出样例1 5: 1 2 3 4 5 5: 1 2 3 4 5 24 10: 1 2 3 4 5 1 2 3 4 5 5: 1 2 3 4 5 18 10: 1 2 3 4 5 1 2 3 4 5 4 19 提示#include <iostream> using namespace std; class LNode { int data; LNode *next; public://以下代码为LNode的相关代码 /********** Write your code here! **********/ /************
04-24
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

谁的BUG最难改

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

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

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

打赏作者

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

抵扣说明:

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

余额充值