PTA 1071 小賭怡情

2021-09-25 23:31:52 字數 1841 閱讀 4984

常言道「小賭怡情」。這是乙個很簡單的小遊戲:首先由計算機給出第乙個整數;然後玩家下注賭第二個整數將會比第乙個數大還是小;玩家下注 t 個籌碼後,計算機給出第二個數。若玩家猜對了,則系統獎勵玩家 t 個籌碼;否則扣除玩家 t 個籌碼。

注意:玩家下注的籌碼數不能超過自己帳戶上擁有的籌碼數。當玩家輸光了全部籌碼後,遊戲就結束。

輸入在第一行給出 2 個正整數 t 和 k(≤ 100),分別是系統在初始狀態下贈送給玩家的籌碼數、以及需要處理的遊戲次數。隨後 k 行,每行對應一次遊戲,順序給出 4 個數字:

n1 b t n2

其中 n1 和 n2 是計算機先後給出的兩個[0, 9]內的整數,保證兩個數字不相等。b 為 0 表示玩家賭小,為 1 表示玩家賭大。t 表示玩家下注的籌碼數,保證在整型範圍內。

對每一次遊戲,根據下列情況對應輸出(其中 t 是玩家下注量,x 是玩家當前持有的籌碼量):

玩家贏,輸出 win t! total = x.;

玩家輸,輸出 lose t. total = x.;

玩家下注超過持有的籌碼量,輸出 not enough tokens. total = x.;

玩家輸光後,輸出 game over. 並結束程式。

100 4

8 0 100 2

3 1 50 1

5 1 200 6

7 0 200 8

win 100! total = 200.

lose 50. total = 150.

not enough tokens. total = 150.

not enough tokens. total = 150.

100 4

8 0 100 2

3 1 200 1

5 1 200 6

7 0 200 8

win 100! total = 200.

lose 200. total = 0.

game over.

這題我用的是結構體和vector來儲存資料。每次迴圈的時候使用結構體儲存每一輪的資料,然後將結構體存入vector中儲存。進行輸出的時候首先判斷t是否要大於0,如果等於0說明籌碼不足,輸出game over.直接退出迴圈結束程式。如果t小於當前輪輸入的t,則表明籌碼不足,跳過該輪,進行下一輪的輸入,並且輸出not enough tokens;如果籌碼足夠,而且猜正確輸出win,否則輸出lose。

這裡一定要注意!千萬不要輸出錯了格式!!!win和lose後面接著total中間帶了兩個空格,而且每一行的輸出末尾都帶有乙個『』.『』。被這個坑的好慘!

#include

#include

using

namespace std;

struct game

;int

main()

for(

int i=

0;isize()

;i++

)// 進行遍歷

else

if(vec[i]

.t>t)

// 如果籌碼還有,但是籌碼不足的時候進行輸出,並且進行下一輪

else

if(vec[i]

.n1>vec[i]

.n2 && vec[i]

.b==

0|| vec[i]

.n1.n2 && vec[i]

.b==1)

// 如果籌碼足夠,而且猜對了

else

// 籌碼足夠但是猜錯了輸出並繼續

1071 小賭怡情

1.解題思路 ans表示n1和n2真實的結果,如果n1 n2,ans為0 表示應該賭小,否則ans 1,表示玩家應該賭大。t表示當前玩家有的籌碼數,如果t 0,表示玩家已經輸光 輸出game over 如果t t,表示玩家下注超過持有的籌碼量 輸出not enough tokens.total 當前...

1071 小賭怡情

常言道 小賭怡情 這是乙個很簡單的小遊戲 首先由計算機給出第乙個整數 然後玩家下注賭第二個整數將會比第乙個數大還是小 玩家下注 t 個籌碼後,計算機給出第二個數。若玩家猜對了,則系統獎勵玩家 t 個籌碼 否則扣除玩家 t 個籌碼。注意 玩家下注的籌碼數不能超過自己帳戶上擁有的籌碼數。當玩家輸光了全部...

PTA 乙級1071 小賭怡情 15 分

常言道 小賭怡情 這是乙個很簡單的小遊戲 首先由計算機給出第乙個整數 然後玩家下注賭第二個整數將會比第乙個數大還是小 玩家下注 t 個籌碼後,計算機給出第二個數。若玩家猜對了,則系統獎勵玩家 t 個籌碼 否則扣除玩家 t 個籌碼。注意 玩家下注的籌碼數不能超過自己帳戶上擁有的籌碼數。當玩家輸光了全部...