[LeetCode] Bulls and Cows

简介: You are playing the following Bulls and Cows game with your friend: You write a 4-digit secret number and ask your friend to guess it. Each time your friend guesses a number, you give a hin

You are playing the following Bulls and Cows game with your friend: You write a 4-digit secret number and ask your friend to guess it. Each time your friend guesses a number, you give a hint. The hint tells your friend how many digits are in the correct positions (called “bulls”) and how many digits are in the wrong positions (called “cows”). Your friend will use those hints to find out the secret number.

For example:

Secret number: “1807”
Friend’s guess: “7810”

Hint: 1 bull and 3 cows. (The bull is 8, the cows are 0, 1 and 7.)
Write a function to return a hint according to the secret number and friend’s guess, use A to indicate the bulls and B to indicate the cows. In the above example, your function should return "1A3B".

Please note that both secret number and friend’s guess may contain duplicate digits, for example:

Secret number: “1123”
Friend’s guess: “0111”

In this case, the 1st 1 in friend’s guess is a bull, the 2nd or 3rd 1 is a cow, and your function should return "1A1B".
You may assume that the secret number and your friend’s guess only contain digits, and their lengths are always equal.

解题思路

  1. 扫描secret字符串,记录各个字符的个数。
  2. 扫描两遍guess字符串:
    ①第一遍记录字符正确且位置也正确的字符。
    ②第二遍记录字符正确但位置不正确的字符。

实现代码

C++:

// Runtime: 20ms
class Solution {
public:
    string getHint(string secret, string guess) {
        unordered_map<char, int> mymap;
        vector<bool> tag(secret.size(), false);
        for (int i = 0; i < secret.size(); i++) {
            mymap[secret[i]]++;
        }

        int cntA = 0;
        int cntB = 0;
        for (int i = 0; i < guess.size(); i++) {
            if (secret[i] == guess[i]) {
                ++cntA;
                tag[i] = true;
                mymap[guess[i]]--;
            }
        }

        for (int i = 0; i < guess.size(); i++) {
            if (!tag[i] && mymap[guess[i]] > 0) {
                cntB++;
                mymap[guess[i]]--;
            }
        }

        return to_string(cntA) + "A" + to_string(cntB) + "B";
    }
private:
    string to_string(int n) {
        if (n == 0)
        {
            return "0";
        }
        string res = "";
        while (n) 
        {
            res += n % 10 + '0';
            n /= 10;
        }
        reverse(res.begin(), res.end());

        return res;
    }
};

Java:

// Runtime: 18ms
public class Solution {
    public String getHint(String secret, String guess) {
        Map<Character, Integer> map = new HashMap<Character, Integer>();
        boolean tag[] = new boolean[secret.length()];
        for (int i = 0; i < secret.length(); i++) {
            if (map.containsKey(secret.charAt(i))) {
                map.replace(secret.charAt(i), map.get(secret.charAt(i)) + 1);
            }
            else {
                map.put(secret.charAt(i), 1);
            }
        }

        int a = 0, b = 0;
        for (int i = 0; i < guess.length(); i++) {
            if(secret.charAt(i) == guess.charAt(i)) {
                ++a;
                map.replace(guess.charAt(i), map.get(guess.charAt(i)) - 1);
                tag[i] = true;
            }
        }

        for (int i = 0; i < guess.length(); i++) {
            if (!tag[i] && map.containsKey(guess.charAt(i)) && map.get(guess.charAt(i)) > 0) {
                ++b;
                map.replace(guess.charAt(i), map.get(guess.charAt(i)) - 1);
            }
        }

        return a + "A" + b + "B";
    }
}
目录
相关文章
LeetCode 299. Bulls and Cows
你正在和你的朋友玩 猜数字(Bulls and Cows)游戏:你写下一个数字让你的朋友猜。每次他猜测后,你给他一个提示,告诉他有多少位数字和确切位置都猜对了(称为“Bulls”, 公牛),有多少位数字猜对了但是位置不对(称为“Cows”, 奶牛)。你的朋友将会根据提示继续猜,直到猜出秘密数字。 请写出一个根据秘密数字和朋友的猜测数返回提示的函数,用 A 表示公牛,用 B 表示奶牛。
116 0
LeetCode 299. Bulls and Cows
[LeetCode]--299. Bulls and Cows
You are playing the following Bulls and Cows game with your friend: You write down a number and ask your friend to guess what the number is. Each time your friend makes a guess, you provide
1152 0
LeetCode 299 Bulls and Cows(公牛和母牛)(HashMap)
版权声明:转载请联系本人,感谢配合!本站地址:http://blog.csdn.net/nomasp https://blog.csdn.net/NoMasp/article/details/52560310 翻译 你在和朋友们玩一个叫做“公牛和母牛”的游戏:你写下一组数字,然后让你的朋友来猜它。
1072 0
|
C++
[LeetCode] Bulls and Cows
This problem seems to be easy at the first glance, especially the problem gives a too much simpler example.
944 0
|
4月前
|
Unix Shell Linux
LeetCode刷题 Shell编程四则 | 194. 转置文件 192. 统计词频 193. 有效电话号码 195. 第十行
本文提供了几个Linux shell脚本编程问题的解决方案,包括转置文件内容、统计词频、验证有效电话号码和提取文件的第十行,每个问题都给出了至少一种实现方法。
LeetCode刷题 Shell编程四则 | 194. 转置文件 192. 统计词频 193. 有效电话号码 195. 第十行
|
5月前
|
Python
【Leetcode刷题Python】剑指 Offer 32 - III. 从上到下打印二叉树 III
本文介绍了两种Python实现方法,用于按照之字形顺序打印二叉树的层次遍历结果,实现了在奇数层正序、偶数层反序打印节点的功能。
69 6
|
5月前
|
搜索推荐 索引 Python
【Leetcode刷题Python】牛客. 数组中未出现的最小正整数
本文介绍了牛客网题目"数组中未出现的最小正整数"的解法,提供了一种满足O(n)时间复杂度和O(1)空间复杂度要求的原地排序算法,并给出了Python实现代码。
137 2
|
2月前
|
机器学习/深度学习 人工智能 自然语言处理
280页PDF,全方位评估OpenAI o1,Leetcode刷题准确率竟这么高
【10月更文挑战第24天】近年来,OpenAI的o1模型在大型语言模型(LLMs)中脱颖而出,展现出卓越的推理能力和知识整合能力。基于Transformer架构,o1模型采用了链式思维和强化学习等先进技术,显著提升了其在编程竞赛、医学影像报告生成、数学问题解决、自然语言推理和芯片设计等领域的表现。本文将全面评估o1模型的性能及其对AI研究和应用的潜在影响。
75 1