mirror of
https://github.com/freeCodeCamp/freeCodeCamp.git
synced 2025-12-31 06:01:50 -05:00
3.0 KiB
3.0 KiB
id, title, challengeType, videoUrl, forumTopicId
| id | title | challengeType | videoUrl | forumTopicId |
|---|---|---|---|---|
| 565bbe00e9cc8ac0725390f4 | 21点游戏 | 1 | https://scrimba.com/c/c6KE7ty | 16809 |
--description--
在赌场 21 点游戏中,玩家可以通过计算牌桌上已经发放的卡牌的高低值来让自己在游戏中保持优势,这就叫21 点算法。
根据下面的表格,每张卡牌都分配了一个值。如果卡牌的值大于 0,那么玩家应该追加赌注。反之,追加少许赌注甚至不追加赌注。
| Count Change | Cards |
|---|---|
| +1 | 2, 3, 4, 5, 6 |
| 0 | 7, 8, 9 |
| -1 | 10, 'J', 'Q', 'K', 'A' |
card的值来递增或递减变量count,函数返回一个由当前count和Bet(count>0)或Hold(count<=0)拼接的字符串。注意count和"Bet"或Hold应该用空格分开。
例如:
-3 Hold
5 Bet
提示
既然 card 的值为 7、8、9 时,count 值不变,那我们就可以忽略这种情况。
--hints--
Cards Sequence 2, 3, 4, 5, 6 应该返回5 Bet。
assert(
(function () {
count = 0;
cc(2);
cc(3);
cc(4);
cc(5);
var out = cc(6);
if (out === '5 Bet') {
return true;
}
return false;
})()
);
Cards Sequence 7, 8, 9 应该返回 0 Hold。
assert(
(function () {
count = 0;
cc(7);
cc(8);
var out = cc(9);
if (out === '0 Hold') {
return true;
}
return false;
})()
);
Cards Sequence 10, J, Q, K, A 应该返回 -5 Hold。
assert(
(function () {
count = 0;
cc(10);
cc('J');
cc('Q');
cc('K');
var out = cc('A');
if (out === '-5 Hold') {
return true;
}
return false;
})()
);
Cards Sequence 3, 7, Q, 8, A 应该返回 -1 Hold。
assert(
(function () {
count = 0;
cc(3);
cc(7);
cc('Q');
cc(8);
var out = cc('A');
if (out === '-1 Hold') {
return true;
}
return false;
})()
);
Cards Sequence 2, J, 9, 2, 7 应该返回 1 Bet。
assert(
(function () {
count = 0;
cc(2);
cc('J');
cc(9);
cc(2);
var out = cc(7);
if (out === '1 Bet') {
return true;
}
return false;
})()
);
Cards Sequence 2, 2, 10 应该返回 1 Bet。
assert(
(function () {
count = 0;
cc(2);
cc(2);
var out = cc(10);
if (out === '1 Bet') {
return true;
}
return false;
})()
);
Cards Sequence 3, 2, A, 10, K 应该返回 -1 Hold。
assert(
(function () {
count = 0;
cc(3);
cc(2);
cc('A');
cc(10);
var out = cc('K');
if (out === '-1 Hold') {
return true;
}
return false;
})()
);