Problem24組合與繼承、makefile、友元函數(shù)

2020-07-08

挺簡(jiǎn)單的,實(shí)現(xiàn)上好像也沒有什么難點(diǎn)······就當(dāng)練習(xí)熟練度了吧。

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

友元函數(shù)

一個(gè)類需要成為另一個(gè)類的友元,而且兩個(gè)人不在同一個(gè)頭文件中時(shí)這樣做:

#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 */


題目說明

題目描述

小明總會(huì)為他接下來的一段日子做一些計(jì)劃和安排。在大多數(shù)日子中,小明總是積極向上。但由于“黑色星期五”的傳說,小明認(rèn)為星期五是一個(gè)特別的日子,因此不希望在周五有任何計(jì)劃。

現(xiàn)在,小明希望你幫他實(shí)現(xiàn)一個(gè)計(jì)劃管理器來進(jìn)行合理規(guī)劃,并對(duì)周五進(jìn)行特別的提醒。

文件下載地址:下載鏈接

輸入樣例

第一行包括一個(gè)正整數(shù)m,表示需要規(guī)劃的總天數(shù)。

接下來m行,每行包括兩個(gè)數(shù)字 a,b以及字符串c,表示本日為a月b日,表示星期幾(如Monday)。

接下來一行包括一個(gè)正整數(shù) k 表示共有多少個(gè)計(jì)劃。

接下來 k行,每行包括兩個(gè)數(shù)字a,b,以及字符串s,表示 a月 b日有一個(gè)內(nèi)容為 s的計(jì)劃。保證日期在之前“需要規(guī)劃的日期”中出現(xiàn)過。

樣例輸入見 example_in.txt

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

輸出樣例

按照輸入順序,依次輸出每天的計(jì)劃安排。對(duì)每天,首先輸出"a/b c"表示是a月b日,星期c。如果當(dāng)天有計(jì)劃,則輸出"Today's Plan:", 之后若干行,按輸入順序每行輸出一個(gè)計(jì)劃的內(nèi)容。如果當(dāng)天無計(jì)劃,則輸出"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. 在已有代碼基礎(chǔ)上編寫 Plan 類,Day 類,F(xiàn)riday 類及Makefile。請(qǐng)合理設(shè)計(jì)三個(gè)類的組合與繼承關(guān)系,人工評(píng)價(jià)會(huì)依照設(shè)計(jì)合理性與可拓展性給分。
  3. 你應(yīng)該生成的可執(zhí)行文件名為 main

限制與約定

2≤m,k≤100

時(shí)間限制:1s

空間限制:256MB

提交格式

根據(jù)提供的 main.cpp 的內(nèi)容,編寫對(duì)應(yīng)的類的代碼( Plan 類,Day 類,F(xiàn)riday 類)。你應(yīng)該將你的文件打包成一個(gè)zip壓縮包并上傳。評(píng)測(cè)時(shí),OJ會(huì)將提供的 main.cpp貼入你的目錄下進(jìn)行編譯并執(zhí)行。

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;
}

評(píng)分標(biāo)準(zhǔn)

OJ評(píng)分占70%,人工評(píng)分占30%。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

友情鏈接更多精彩內(nèi)容