LeetCode:猜数字游戏

解决方案的性能:

时间复杂度:O(n)

题目描述:

写出一个秘密数字,并请朋友猜这个数字是多少。朋友每猜测一次,你就会给他一个包含下述信息的提示:

  • 猜测数字中有多少位属于数字和确切位置都猜对了(称为 "Bulls",公牛),
  • 有多少位属于数字猜对了但是位置不对(称为 "Cows",奶牛)。也就是说,这次猜测中有多少位非公牛数字可以通过重新排列转换成公牛数字。

给你一个秘密数字 secret 和朋友猜测的数字 guess ,请你返回对朋友这次猜测的提示。

提示的格式为 "xAyB" ,x 是公牛个数, y 是奶牛个数,A 表示公牛,B 表示奶牛。

请注意秘密数字和朋友猜测的数字都可能含有重复数字。

示例 1:

输入:secret = "1807", guess = "7810"
输出:"1A3B"

示例 2:

输入:secret = "1123", guess = "0111"
输出:"1A1B"

注意,两个不匹配的 1 中,只有一个会算作奶牛。因为通过重新排列非公牛数字,其中仅有一个 1 可以成为公牛数字。

 解题思路:

本题中公牛的数目很显而易见地可以去遍历统计。而母牛数目则可以利用“桶”的优势,在统计公牛数目的同时找到。

具体做法是利用“桶”去统计secret和guess中除开公牛以外,各数字的出现数目。而依据母牛的定义不难发现:当guess中数字的数目少于或等于secret中时,guess中所有该数字都是母牛;反正secret中的所有该数字都是母牛。

代码实现:

class Solution {
public:
    string getHint(string secret, string guess) {
        int s[10] = {0,0,0,0,0,0,0,0,0,0};
	    int g[10] = {0,0,0,0,0,0,0,0,0,0};
	    int bull = 0,cow = 0;
	
	    for(int i = 0; i < guess.length(); i++) {
		    if(secret[i] == guess[i])  bull++;
		    else {
			    s[secret[i] - 48]++;
			    g[guess[i] - 48]++;
		    }
	    }

	    for(int i = 0; i < 10; i++){
		    if(g[i] <= s[i])  cow += g[i];
		    else  cow += s[i];
	    }
	    return to_string(bull) + 'A' + to_string(cow) + 'B';
    }
};

相关推荐

  1. LeetCode数字游戏

    2024-03-11 16:30:05       48 阅读
  2. leetcode299--数字游戏

    2024-03-11 16:30:05       41 阅读
  3. LeetCode 0299.数字游戏:计数

    2024-03-11 16:30:05       48 阅读
  4. 数字游戏

    2024-03-11 16:30:05       37 阅读
  5. Linux数字游戏

    2024-03-11 16:30:05       24 阅读
  6. LeetCode每日一题[C++]-数字游戏

    2024-03-11 16:30:05       53 阅读

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2024-03-11 16:30:05       94 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-03-11 16:30:05       100 阅读
  3. 在Django里面运行非项目文件

    2024-03-11 16:30:05       82 阅读
  4. Python语言-面向对象

    2024-03-11 16:30:05       91 阅读

热门阅读

  1. LeetCode每日一题[C++]-猜数字游戏

    2024-03-11 16:30:05       53 阅读
  2. 基本工具学习--宝藏“课程”

    2024-03-11 16:30:05       46 阅读
  3. AcWing 1211. 蚂蚁感冒

    2024-03-11 16:30:05       43 阅读
  4. sora未来在哪里,是否改变世界

    2024-03-11 16:30:05       43 阅读
  5. 2024 年 AI 辅助研发趋势

    2024-03-11 16:30:05       43 阅读
  6. sqlite 损坏 修复

    2024-03-11 16:30:05       43 阅读
  7. C语言基础练习——Day04

    2024-03-11 16:30:05       37 阅读
  8. 如何像专家一样维护服务器硬件?

    2024-03-11 16:30:05       38 阅读
  9. 大数据开发(Hadoop面试真题-卷二)

    2024-03-11 16:30:05       36 阅读
  10. Superset二次开发之Superset架构理解

    2024-03-11 16:30:05       40 阅读
  11. 关于tensorrt里面的wts校验

    2024-03-11 16:30:05       35 阅读
  12. 浅谈SpringAOP实现原理

    2024-03-11 16:30:05       44 阅读