傳送門
https://pintia.cn/problem-sets/994805260223102976/problems/994805264312549376
題目
常言道“小賭怡情”。這是一個很簡單的小游戲:首先由計算機(jī)給出第一個整數(shù);然后玩家下注賭第二個整數(shù)將會比第一個數(shù)大還是?。煌婕蚁伦個籌碼后,計算機(jī)給出第二個數(shù)。若玩家猜對了,則系統(tǒng)獎勵玩家t個籌碼;否則扣除玩家t個籌碼。
注意:玩家下注的籌碼數(shù)不能超過自己帳戶上擁有的籌碼數(shù)。當(dāng)玩家輸光了全部籌碼后,游戲就結(jié)束。
輸入格式:
輸入在第一行給出2個正整數(shù)T和K(<=100),分別是系統(tǒng)在初始狀態(tài)下贈送給玩家的籌碼數(shù)、以及需要處理的游戲次數(shù)。隨后K行,每行對應(yīng)一次游戲,順序給出4個數(shù)字:
n1 b t n2
其中n1和n2是計算機(jī)先后給出的兩個[0, 9]內(nèi)的整數(shù),保證兩個數(shù)字不相等。b為0表示玩家賭“小”,為1表示玩家賭“大”。t表示玩家下注的籌碼數(shù),保證在整型范圍內(nèi)。
輸出格式:
對每一次游戲,根據(jù)下列情況對應(yīng)輸出(其中t是玩家下注量,x是玩家當(dāng)前持有的籌碼量):
玩家贏,輸出“Win t! Total = x.”;
玩家輸,輸出“Lose t. Total = x.”;
玩家下注超過持有的籌碼量,輸出“Not enough tokens. Total = x.”;
玩家輸光后,輸出“Game Over.”并結(jié)束程序。
輸入樣例1:
100 4
8 0 100 2
3 1 50 1
5 1 200 6
7 0 200 8
輸出樣例1:
Win 100! Total = 200.
Lose 50. Total = 150.
Not enough tokens. Total = 150.
Not enough tokens. Total = 150.
輸入樣例2:
100 4
8 0 100 2
3 1 200 1
5 1 200 6
7 0 200 8
輸出樣例2:
Win 100! Total = 200.
Lose 200. Total = 0.
Game Over.
分析
第一道題,難度不大,就是條件看著有點亂,另外注意下以下幾點:
(1) 下注超限的情況應(yīng)該在最初判斷;
(2) 每次猜對或猜錯輸出提示的時候,應(yīng)該先將本局籌碼結(jié)清,再報當(dāng)前剩余籌碼,猜錯的情況也是;
(3) 每輪判斷完后,要判斷籌碼是否小于0,如果小于0,終止游戲;
(4) 另外“win t!”后面跟著兩個空格,“Lose t.”后面也是,我之前都只空了一格。
源代碼
//C/C++實現(xiàn)
#include <iostream>
using namespace std;
int main(){
int T; // 初始狀態(tài)下贈送給玩家的籌碼數(shù)
int K; // 需要處理的游戲次數(shù)
scanf("%d %d", &T, &K);
int n1;
int b; // b為0表示n2<n1 b為1表示n2>n1
int t; // 玩家下注的籌碼數(shù)
int n2;
for(int i = 0; i < K; ++i){
scanf("%d %d %d %d", &n1, &b, &t, &n2);
if(t > T){ //下注超限
cout << "Not enough tokens. Total = "<< T << "." << endl;
}
else{
if(n2 < n1 && b == 0 || n2 > n1 && b == 1){ // 猜對了
T += t;
cout << "Win " << t <<"! Total = " << T << "." << endl;
}
else{ // 猜錯了
T -= t;
cout << "Lose " << t <<". Total = " << T << "." << endl;
}
}
if(T <= 0){
printf("Game Over.\n");
break;
}
}
return 0;
}