PAT-B 1071. 小賭怡情(15)

傳送門

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
其中n1n2是計算機(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;
}
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容