zoukankan      html  css  js  c++  java
  • Basic JavaScript: Counting Cards

    In the casino game Blackjack, a player can gain an advantage over the house by keeping track of the relative number of high and low cards remaining in the deck. This is called Card Counting.

    Having more high cards remaining in the deck favors the player. Each card is assigned a value according to the table below. When the count is positive, the player should bet high. When the count is zero or negative, the player should bet low.

    Count Change Cards
    +1 2, 3, 4, 5, 6
    0 7, 8, 9
    -1 10, 'J', 'Q', 'K', 'A'

    You will write a card counting function. It will receive a card parameter, which can be a number or a string, and increment or decrement the global count variable according to the card's value (see table). The function will then return a string with the current count and the string Bet if the count is positive, or Hold if the count is zero or negative. The current count and the player's decision (Bet or Hold) should be separated by a single space.

    Example Output
    -3 Hold
    5 Bet

    Hint
    Do NOT reset count to 0 when value is 7, 8, or 9.
    Do NOT return an array.
    Do NOT include quotes (single or double) in the output.

    Solution 1

    // CountingCards.js
    let count = 0;
    
    function CountingCards(card) {
        let regex = /[JQKA]/;
        
        if (card > 1 && card < 7) {
            count++;
        } else if (card === 10 || card.toString().match(regex)) {
            count--;
        }
        
        if (count > 0) 
            return count + " Bet";
        return count + " Hold";
    }
    
    console.log(CountingCards(2));
    console.log(CountingCards(3));
    console.log(CountingCards(7));
    console.log(CountingCards('K'));
    console.log(CountingCards('A'));
    

    Solution 2

    let count = 0;
    
    function CountingCards(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--;
                break;            
        }
        if (count > 0) {
            return count + " Bet";
        } else {
            return count + " Hold";
        }
    }
    
    console.log(CountingCards(2));
    console.log(CountingCards(3));
    console.log(CountingCards(7));
    console.log(CountingCards('K'));
    console.log(CountingCards('A'));
    

    Cards Sequence 2, 3, 4, 5, 6 should return 5 Bet

    Cards Sequence 7, 8, 9 should return 0 Hold

    Cards Sequence 10, J, Q, K, A should return -5 Hold

    Cards Sequence 3, 7, Q, 8, A should return -1 Hold

    Cards Sequence 2, J, 9, 2, 7 should return 1 Bet

    Cards Sequence 2, 2, 10 should return 1 Bet

    Cards Sequence 3, 2, A, 10, K should return -1 Hold

  • 相关阅读:
    javascript入门 之 zTree(十四 增删查改)(二)
    javascript入门 之 zTree(十四 增删查改)(一)
    javascript入门 之 zTree(十三 移动/复制事件)
    javascript入门 之 bind() (二)
    javascript入门 之 zTree(十二 托拽事件(二))
    javascript入门 之 zTree(十一 托拽事件(一))
    Java 使用 switch 语句和枚举类型
    微信公众号开发(四)—— 自定义菜单的创建
    微信公众号开发(三)——获取 Access_Token
    微信公众号开发(二)—— 图文消息
  • 原文地址:https://www.cnblogs.com/PrimerPlus/p/13022408.html
Copyright © 2011-2022 走看看