c語言競賽是浙江大學計算機學院主持的乙個歡樂的競賽。既然競賽主旨是為了好玩,頒獎規則也就制定得很滑稽:
冠軍將贏得乙份「神秘大獎」(比如很巨大的一本學生研究**集……)。
排名為素數的學生將贏得最好的獎品 —— 小黃人玩偶!
其他人將得到巧克力。
給定比賽的最終排名以及一系列參賽者的id,你要給出這些參賽者應該獲得的獎品。
輸入格式:
輸入第一行給出乙個正整數n(<=10000),是參賽者人數。隨後n行給出最終排名,每行按排名順序給出一位參賽者的id(4位數字組成)。接下來給出乙個正整數k以及k個需要查詢的id。
輸出格式:
對每個要查詢的id,在一行中輸出「id: 獎品」,其中獎品或者是「mystery award」(神秘大獎)、或者是「minion」(小黃人)、或者是「chocolate」(巧克力)。如果所查id根本不在排名裡,列印「are you kidding?」(耍我呢?)。如果該id已經查過了(即獎品已經領過了),列印「id: checked」(不能多吃多占)。
輸入樣例:
6 1111
6666
8888
1234
5555
0001
6 8888
0001
1111
2222
8888
2222
輸出樣例:
8888: minion
0001: chocolate
1111: mystery award
2222: are you kidding?
8888: checked
2222: are you kidding?
分析 這裡編號和名次都是10000以下的數字,我們可以建立乙個長度為10000的陣列初始化為0,把名次作為值,把id作為下標。注意幾個判斷條件的依次順序
#include
#include
#include
using
namespace
std;
bool isodd(int k)
}return
true;
}int main()
; int n;
cin>>n;
for(int i=0;iint tmp;
cin>>tmp;
score[tmp]=i+1;
}int k;
cin>>k;
for(int i=0;iint tmp;
cin>>tmp;
if(tmp<1000)cout
<<"0";
if(tmp<100)cout
<<"0";
if(tmp<10)cout
<<"0";
cout
<": ";
if(score[tmp]==-2)
if(score[tmp]>0)else}}
return
0; }
1059 C語言競賽 20
c語言競賽是浙江大學計算機學院主持的乙個歡樂的競賽。既然競賽主旨是為了好玩,頒獎規則也就制定得很滑稽 冠軍將贏得乙份 神秘大獎 比如很巨大的一本學生研究 集 排名為素數的學生將贏得最好的獎品 小黃人玩偶!其他人將得到巧克力。給定比賽的最終排名以及一系列參賽者的id,你要給出這些參賽者應該獲得的獎品。...
1059 C語言競賽 20
時間限制 200 ms 記憶體限制 65536 kb 長度限制 8000 b 判題程式 standard 作者 chen,yue c語言競賽是浙江大學計算機學院主持的乙個歡樂的競賽。既然競賽主旨是為了好玩,頒獎規則也就制定得很滑稽 0.冠軍將贏得乙份 神秘大獎 比如很巨大的一本學生研究 集 1.排名...
1059 C語言競賽 20
c語言競賽是浙江大學計算機學院主持的乙個歡樂的競賽。既然競賽主旨是為了好玩,頒獎規則也就制定得很滑稽 冠軍將贏得乙份 神秘大獎 比如很巨大的一本學生研究 集 排名為素數的學生將贏得最好的獎品 小黃人玩偶!其他人將得到巧克力。給定比賽的最終排名以及一系列參賽者的id,你要給出這些參賽者應該獲得的獎品。...