Problem24组合与继承、makefile、友元函数

2020-07-08

挺简单的,实现上好像也没有什么难点······就当练习熟练度了吧。

makefile

值得注意的是两类makefile模板:

编译链接分开

all: main

main: main.o Computer.o ComputerCollection.o
    g++ main.o Computer.o ComputerCollection.o -o main -O2 -std=c++11

main.o: main.cpp Computer.cpp ComputerCollection.cpp
    g++ -c main.cpp -o main.o -O2 -std=c++11

ComputerCollection.o: ComputerCollection.cpp Computer.cpp
    g++ -c ComputerCollection.cpp -o ComputerCollection.o -O2 -std=c++11

Computer.o: Computer.cpp
    g++ -c Computer.cpp -o Computer.o -O2 -std=c++11

clean: 
    rm -fR *.o main

编译链接一起做

all: main

main: main.cpp plan.h day.h friday.h
    g++ main.cpp -o main -O2 -std=c++11

clean: 
    rm -fR *.o main

友元函数

一个类需要成为另一个类的友元,而且两个人不在同一个头文件中时这样做:

#ifndef plan_hpp
#define plan_hpp

#include <stdio.h>
#include <string>
#include <vector>
#include <iostream>
using namespace std;
/*这里先声明一下*/
class Day;

class Plan {
    int month,day;
    string c;
    
public:
    friend class Day;
    Plan(int a,int b,string c):month(a),day(b),c(c){
    }
    string myPlan(){
        return c;
    }
};

#endif /* plan_hpp */

#ifndef day_hpp
#define day_hpp

#include "plan.h"
#include <stdio.h>

class Day {
protected:
    int month;
    int day;
    string c;
    vector<Plan> plans;
    //这里直接用就好了
    bool isOneDay(Plan t){
        return (month==t.month)&&(day==t.day);
    }
......

};

#endif /* day_hpp */


题目说明

题目描述

小明总会为他接下来的一段日子做一些计划和安排。在大多数日子中,小明总是积极向上。但由于“黑色星期五”的传说,小明认为星期五是一个特别的日子,因此不希望在周五有任何计划。

现在,小明希望你帮他实现一个计划管理器来进行合理规划,并对周五进行特别的提醒。

文件下载地址:下载链接

输入样例

第一行包括一个正整数m,表示需要规划的总天数。

接下来m行,每行包括两个数字 a,b以及字符串c,表示本日为a月b日,表示星期几(如Monday)。

接下来一行包括一个正整数 k 表示共有多少个计划。

接下来 k行,每行包括两个数字a,b,以及字符串s,表示 a月 b日有一个内容为 s的计划。保证日期在之前“需要规划的日期”中出现过。

样例输入见 example_in.txt

3
1 1 Thursday
1 2 Friday
1 3 Saturday
3
1 1 Work
1 2 Study
1 1 Swim

输出样例

按照输入顺序,依次输出每天的计划安排。对每天,首先输出"a/b c"表示是a月b日,星期c。如果当天有计划,则输出"Today's Plan:", 之后若干行,按输入顺序每行输出一个计划的内容。如果当天无计划,则输出"Today is Free"。

特别的,如果是周五,则额外输出一行:"Friday is Busy :("或"Friday is Free :)"。

完整输出见 example_out.txt

1/1 Thursday Today's Plan:
Work
Swim
1/2 Friday Today's Plan:
Study
Friday is Busy :(
1/3 Saturday Today is Free

要求

  1. 不修改 main.cpp
  2. 在已有代码基础上编写 Plan 类,Day 类,Friday 类及Makefile。请合理设计三个类的组合与继承关系,人工评价会依照设计合理性与可拓展性给分。
  3. 你应该生成的可执行文件名为 main

限制与约定

2≤m,k≤100

时间限制:1s

空间限制:256MB

提交格式

根据提供的 main.cpp 的内容,编写对应的类的代码( Plan 类,Day 类,Friday 类)。你应该将你的文件打包成一个zip压缩包并上传。评测时,OJ会将提供的 main.cpp贴入你的目录下进行编译并执行。

main.cpp:

#include "friday.h"
#include "day.h"
#include "plan.h"
#include <iostream>
#include <string>

Day* days[101];
int main()
{
    int m, k, a, b;
    std::string c;
    std::cin >> m;
    for(int i = 0; i < m; ++i)
    {
        std::cin >> a >> b >> c;
        if(c == "Friday")
            days[i] = new Friday(a, b, c);
        else
            days[i] = new Day(a, b, c);
    }
    std::cin >> k;
    while(k--)
    {
        std::cin >> a >> b >> c;
        Plan t(a, b, c);
        for(int i = 0; i < m; ++i)
            if(days[i]->insert(t))
                break;
    }
    for(int i = 0; i < m; ++i)
        days[i]->print();
    return 0;
}

评分标准

OJ评分占70%,人工评分占30%。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。