【测试点分析】1072 开学寄语 (20分)_42行代码AC
立志用更少的代碼做更高效的表達
Pat乙級最優(yōu)化代碼+題解+分析匯總——>傳送門
下圖是上海某校的新學(xué)期開學(xué)寄語:天將降大任于斯人也,必先刪其微博,卸其 QQ,封其電腦,奪其手機,收其 ipad,斷其 wifi,使其百無聊賴,然后,凈面、理發(fā)、整衣,然后思過、讀書、鍛煉、明智、開悟、精進。而后必成大器也!
本題要求你寫個程序幫助這所學(xué)校的老師檢查所有學(xué)生的物品,以助其成大器。
輸入格式:
輸入第一行給出兩個正整數(shù) N(≤ 1000)和 M(≤ 6),分別是學(xué)生人數(shù)和需要被查繳的物品種類數(shù)。第二行給出 M 個需要被查繳的物品編號,其中編號為 4 位數(shù)字。隨后 N 行,每行給出一位學(xué)生的姓名縮寫(由 1-4 個大寫英文字母組成)、個人物品數(shù)量 K(0 ≤ K ≤ 10)、以及 K 個物品的編號。
輸出格式:
順次檢查每個學(xué)生攜帶的物品,如果有需要被查繳的物品存在,則按以下格式輸出該生的信息和其需要被查繳的物品的信息(注意行末不得有多余空格):
姓名縮寫: 物品編號1 物品編號2 ……
最后一行輸出存在問題的學(xué)生的總?cè)藬?shù)和被查繳物品的總數(shù)。
輸入樣例:
4 2
2333 6666
CYLL 3 1234 2345 3456
U 4 9966 6666 8888 6666
GG 2 2333 7777
JJ 3 0012 6666 2333
輸出樣例:
U: 6666 6666
GG: 2333
JJ: 6666 2333
3 5
分析
簡單模擬
1、使用unordered_map映射判斷是否為違禁物品
2、定義student結(jié)構(gòu)體,存放帶有違禁物品學(xué)生的姓名和物品號
3、注意輸出前導(dǎo)0(測試點2)
代碼
#include<bits/stdc++.h> using namespace std; struct student{string name;vector<int>v; }stu[1010]; int main() {int N, M; cin >> N >> M;unordered_map<int, int>m;while(M--) {int x; cin >> x; m[x] = 1;} // cout << '\n' << m[2222] << '\n'; int num_stu = 0, num_thing = 0, k = 0; for(int i = 0; i < N; i++) {string s; int num;cin >> s >> num;bool flag = false;while(num--) {int x; cin >> x;if(m[x] > 0) {if(flag == false) { //第一次還要存一下名字 flag = true;stu[k].name = s;num_stu++;}stu[k].v.push_back(x);num_thing++;} }}for(int i = 0; i < k; i++) {cout << stu[i].name << ": ";for(int j = 0; j < stu[i].v.size(); j++) {if(j != 0) cout << ' ';cout << stu[i].v[j];}putchar('\n');} cout << num_stu << ' ' << num_thing << '\n';return 0; }耗時
每日一句
大鵬鳥也要折翅的時候,只要他養(yǎng)好了傷,會飛的更高,更遠。
總結(jié)
以上是生活随笔為你收集整理的【测试点分析】1072 开学寄语 (20分)_42行代码AC的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 【简洁代码】1071 小赌怡情 (15分
- 下一篇: 【简便解法】1074 宇宙无敌加法器 (