在学习JavaScript过程中遇到下面一个有意思的题目。
在赌场21点游戏中,玩家可以通过计算牌桌上已经发放的卡牌的高低值来让自己在游戏中保持优势,这就叫21点算法。
根据下面的表格,每张卡牌都分配了一个值。如果卡牌的值大于0,那么玩家应该追加赌注。反之,追加少许赌注甚至不追加赌注。
Count Change | Cards |
---|---|
+1 | 2, 3, 4, 5, 6 |
0 | 7, 8, 9 |
-1 | 10, 'J', 'Q', 'K','A' |
你需要写一个函数,实现21点算法,它根据参数 card
的值来递增或递减变量count
,函数返回一个由当前count
和 "Bet"
(count>0
)或"Hold"
(count<=0
) 拼接的字符串。注意count
和"Bet"
或 "Hold"
应该用空格分开。
例如:"-3 Hold"
"5 Bet"
一开始写的代码如下:结果是:NANbet。
var count = 0;
function cc(card) {
// Only change code below this line
// var count = 0;
if(card <7){
++count ;
}else if(card >9 || isNaN(card)){
--count ;
}
if(count <= 0){
count= count + " Hold";
}else{
count= count + " Bet";
}
return count;
// Only change code above this line
}
// Add/remove calls to test your function.
// 提示: Only the last will display
cc(2); cc(3); cc(10);
后面去网上查下是不是我的方法有问题,同事也查到了其他的解决方法,但是相对而言代码量较多,最后发现在原先代码画线部分做如下更改就可以解决问题:
if(count <= 0){
return count + " Hold";
}else{
return count + " Bet";
}