PAT Basic 1073 多選題常見計分法

2021-09-22 17:36:02 字數 2781 閱讀 1153

多選題常見計分法(20)

時間限制

400 ms

記憶體限制

65536 kb

**長度限制

8000 b

判題程式

standard

作者chen, yue

批改多選題是比較麻煩的事情,有很多不同的計分方法。有一種最常見的計分方法是:如果考生選擇了部分正確選項,並且沒有選擇任何錯誤選項,則得到50%分數;如果考生選擇了任何乙個錯誤的選項,則不能得分。本題就請你寫個程式幫助老師批改多選題,並且指出哪道題的哪個選項錯的人最多。

輸入格式:

輸入在第一行給出兩個正整數n(<=1000)和m(<=100),分別是學生人數和多選題的個數。隨後m行,每行順次給出一道題的滿分值(不超過5的正整數)、選項個數(不少於2且不超過5的正整數)、正確選項個數(不超過選項個數的正整數)、所有正確選項。注意每題的選項從小寫英文本母a開始順次排列。各項間以1個空格分隔。最後n行,每行給出乙個學生的答題情況,其每題答案格式為「(選中的選項個數 選項1 ……)」,按題目順序給出。注意:題目保證學生的答題情況是合法的,即不存在選中的選項數超過實際選項數的情況。

輸出格式:

按照輸入的順序給出每個學生的得分,每個分數佔一行,輸出小數點後1位。最後輸出錯得最多的題目選項的資訊,格式為:「錯誤次數 題目編號(題目按照輸入的順序從1開始編號)-選項號」。如果有並列,則每行乙個選項,按題目編號遞增順序輸出;再並列則按選項號遞增順序輸出。行首尾不得有多餘空格。如果所有題目都沒有人錯,則在最後一行輸出「too ******」。

輸入樣例1:

3 43 4 2 a c

2 5 1 b

5 3 2 b c

1 5 4 a b d e

(2 a c) (3 b d e) (2 a c) (3 a b e)

(2 a c) (1 b) (2 a b) (4 a b d e)

(2 b d) (1 e) (1 c) (4 a b c d)

輸出樣例1:

3.56.0

2.52 2-e

2 3-a

2 3-b

輸入樣例2:

2 23 4 2 a c

2 5 1 b

(2 a c) (1 b)

(2 a c) (1 b)

輸出樣例2:

5.05.0

too ******

題目僅僅是麻煩點,算水題。

但是坑在於,如果用c++,讀取資料,需要用getline的對吧,但是全部行都需要用getline嗎,一開始我覺得第一行的m n兩個資料不需要getline而是用cin讀取,那麼cin之後和getline之前插播乙個getchar()就能正確處理了吧。

題目的坑就在這裡,cin了m和n後還有個空格,所以需要兩次getchar();但是不是每組測試用例都是在m和n後面有空格,所以有時候只需要一次getchar(),兩次則報錯。實際上,這裡讀取n和m,我用cin+乙個getchar(),能過3,4,5組測試用例。用cin+兩個getchar(),能過1,2組測試用例

我就無語了,為什麼這麼個小題,非要在這種蛋疼的地方卡人?不是我黑pat,這種測試用例應該避免出現。

最後,全都換成getline()處理,然後在istringstream讀入,就不報錯了。

#include 

#include

#include

#include

#include

#include

#include

#include

#include

#include

#include

#include

using

namespace std;

struct timu

}};struct stu

else

if (isdigit(s[i]))

ans.push_back(t_ans);}}

}};void do_calc(vector& vtimu, vector& vstu)

else }}

double t_score = 0;

if (right_cnt == vtimu[j].num_of_choice)

else

if (!wuxuan)

vstu[i].score += t_score;

//cout << "student[" << i << "] has: right_cnt=" << right_cnt << ", wrong_cnt=" << wrong_cnt << ", get score=" << t_score << endl;}}

}string int2str(int a)

vectordo_stat(const vector& vtimu) }}

vectorres;

string rr = "";

if (max_val == 0)

else

}//cout << endl;

}return res;

}}int main()

vectorvstu;

for (int i = 0; i < n; i++)

do_calc(vtimu, vstu);

for (int i = 0; i < vstu.size(); i++)

vectorres = do_stat(vtimu);

for (int i = 0; i < res.size(); i++)

return

0;}

PAT BASIC1073 多選題常見計分法

我的pat basic 倉 題目描述 知識點 計數 本題和pat basic1058 選擇題的題幹是一模一樣的。區別在於本題還需要額外統計每道題每個選項的錯誤資訊。因此我們不能像pat basic1058 選擇題的思路一樣,把正確選項數量和具體的正確選項當作是乙個字串處理,我們必須讀取每乙個正確的選...

1073 多選題常見計分法

批改多選題是比較麻煩的事情,有很多不同的計分方法。有一種最常見的計分方法是 如果考生選擇了部分正確選項,並且沒有選擇任何錯誤選項,則得到50 分數 如果考生選擇了任何乙個錯誤的選項,則不能得分。本題就請你寫個程式幫助老師批改多選題,並且指出哪道題的哪個選項錯的人最多。輸入格式 輸入在第一行給出兩個正...

1073 多選題常見計分法

1073 多選題常見計分法 20 分 批改多選題是比較麻煩的事情,有很多不同的計分方法。有一種最常見的計分方法是 如果考生選擇了部分正確選項,並且沒有選擇任何錯誤選項,則得到 50 分數 如果考生選擇了任何乙個錯誤的選項,則不能得分。本題就請你寫個程式幫助老師批改多選題,並且指出哪道題的哪個選項錯的...