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