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

题目描述

已知日期类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行

样例查看模式

正常显示查看格式

输入样例1 <-复制

输出样例1

#include<iostream>
using namespace std;
class Time;//注意这里要提前声明一下
class Date
{
public:
    Date(int year, int month, int day)
    {
        this->year = year;
        this->month = month;
        this->day = day;
    }
    friend void Display(const Date& d, const Time& t);
private:
    int year;
    int month;
    int day;
};
class Time
{
public:
    Time(int hour, int min, int sec)
    {
        this->hour = hour;
        this->min = min;
        this->sec = sec;
    }
    friend void Display(const Date& d, const Time& t);
private:
    int hour;
    int min;
    int sec;
};

void Display(const Date& d, const Time& t)
{
    cout << d.year << "-";
    if (d.month < 10)
    {
        cout << "0"<<d.month;
    }
    else
    {
        cout << d.month;
    }
    cout << "-";
    if (d.day < 10)
    {
        cout << "0" << d.day;
    }
    else
    {
        cout << d.day;
    }
    cout << " ";
    if (t.hour < 10)
    {
        cout << "0" << t.hour;
    }
    else
    {
        cout << t.hour;
    }
    cout << ":";
    if (t.min < 10)
    {
        cout << "0" << t.min;
    }
    else
    {
        cout << t.min;
    }
    cout << ":";
    if (t.sec < 10)
    {
        cout << "0" << t.sec;
    }
    else
    {
        cout << t.sec;
    }
    cout << endl;
}
int main()
{
    int t;
    cin >> t;
    int year, month, day;
    int hour, min, sec;
    while (t--)
    {
        cin >> year >> month >> day >> hour >> min >> sec;
        Date d(year, month, day);
        Time t(hour, min, sec);
        Display(d, t);
    }
    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
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值