栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > Java

【LeetCode笔记】299. 猜数字游戏 (Java、偏数学)

Java 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

【LeetCode笔记】299. 猜数字游戏 (Java、偏数学)

文章目录
  • 题目描述
  • 思路 && 代码

题目描述
  • 顶级阅读题!
  • 今天的每日一题,感觉评论区大佬的写法挺值得记录的,就又水了一篇答题文~
思路 && 代码
  • O(n)、O(1)
  • 核心代码:Case 2 的两个 if 处理,挺精髓的!
    • 这里主要是先存储状态,在后期满足条件的情况下维护奶牛的计数值!
class Solution {
    public String getHint(String secret, String guess) {
        int x = 0, y = 0;
        int[] counts = new int[10]; // 存储未被猜对的秘密数字
        for(int i = 0; i < secret.length() && i < guess.length(); i++) {
            // Case 1: 公牛
            if(secret.charAt(i) == guess.charAt(i)) {
                x++;
            } else { // Case 2:奶牛
                if(counts[guess.charAt(i) - '0']-- > 0) { // 2.1:猜了啥就减少啥
                    y++; // 满足 > 0 情况,有得减,y++ !
                }
                if(counts[secret.charAt(i) - '0']++ < 0) { // 2.2:对应啥就增加啥
                    y++; // 满足 < 0 情况,之前被减过,y++ !
                }
            }
        }
        return x + "A" + y + "B";
    }
}
  • 无注释
class Solution {
    public String getHint(String secret, String guess) {
        int x = 0, y = 0;
        int[] counts = new int[10]; 
        for(int i = 0; i < secret.length() && i < guess.length(); i++) {
            if(secret.charAt(i) == guess.charAt(i)) x++;
            else { 
                if(counts[guess.charAt(i) - '0']-- > 0) y++;
                if(counts[secret.charAt(i) - '0']++ < 0) y++;
            }
        }
        return x + "A" + y + "B";
    }
}
转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/445508.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号