多選題常見計分法(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 分數 如果考生選擇了任何乙個錯誤的選項,則不能得分。本題就請你寫個程式幫助老師批改多選題,並且指出哪道題的哪個選項錯的...