freeCodeCamp/curriculum/challenges/chinese-traditional/02-javascript-algorithms-an.../basic-javascript/counting-cards.md

3.7 KiB
Raw Blame History

id title challengeType videoUrl forumTopicId dashedName
565bbe00e9cc8ac0725390f4 21 點遊戲 1 https://scrimba.com/c/c6KE7ty 16809 counting-cards

--description--

在賭場 21 點遊戲中,玩家可以通過計算牌桌上已經發放的卡牌的高低值來讓自己在遊戲中保持優勢。 這就叫 21 點算法

牌桌上的大值的卡牌更多,對玩家有利。 根據下面的表格,每張卡牌都被分配了一個值。 如果卡牌的值大於 0那麼玩家應該追加賭注。 如果卡牌的值爲 0 或負數,玩家應該追加少許賭注甚至不追加賭注。

計數卡牌
+12, 3, 4, 5, 6
07, 8, 9
-110, 'J', 'Q', 'K', 'A'

請寫一個函數實現 21 點算法。 它根據參數 card 的值(見表格,可能是數字或者字符串)來遞增或遞減全局變量 count。 然後函數返回一個由當前 count計數Bet(當 count > 0 時)或 Hold(當 count <= 0 時) 拼接的字符串。 注意 count計數和玩家的決定BetHold)之間應該有空格。

示例輸出:-3 Hold 或者 5 Bet

提示:
當卡牌爲 7、8、9 時,不要把 count 值重置爲 0。 不要返回一個數組。
輸出結果中不要包含單引號或雙引號。

--hints--

卡牌序列 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;
  })()
);

卡牌序列 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;
  })()
);

卡牌序列 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;
  })()
);

卡牌序列 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;
  })()
);

卡牌序列 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;
  })()
);

卡牌序列 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;
  })()
);

卡牌序列 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;
  })()
);

--seed--

--seed-contents--

var count = 0;

function cc(card) {
  // Only change code below this line


  return "Change Me";
  // Only change code above this line
}

cc(2); cc(3); cc(7); cc('K'); cc('A');

--solutions--

var count = 0;
function cc(card) {
  switch(card) {
    case 2:
    case 3:
    case 4:
    case 5:
    case 6:
      count++;
      break;
    case 10:
    case 'J':
    case 'Q':
    case 'K':
    case 'A':
      count--;
  }
  if(count > 0) {
    return count + " Bet";
  } else {
    return count + " Hold";
  }
}