Leetcode374. 猜数字大小

该文介绍了LeetCode中374题的解决方案,使用二分查找策略来猜一个1到n之间的数字。当API返回-1时,搜索左区间;返回1时,搜索右区间;返回0则找到答案。注意防止整数溢出并提供时间复杂度和空间复杂度的分析。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

Every day a leetcode

题目来源:374. 猜数字大小

解法1:二分

设begin=1,end=n,mid为两者的均值。

基于二分查找的思想:

  • guess(mid) == -1:我选出的数字比你猜的数字小 pick < mid,取左区间,end = mid - 1;
  • guess(mid) == 1:我选出的数字比你猜的数字大 pick > mid,取右区间,begin = mid + 1;
  • guess(mid) == 0:我选出的数字和你猜的数字一样。返回mid。

注意mid = (begin + end) / 2会爆int,导致Runtime error,应该用mid = begin + (end - begin) / 2。

代码:

/*
 * @lc app=leetcode.cn id=374 lang=cpp
 *
 * [374] 猜数字大小
 */

// @lc code=start
/**
 * Forward declaration of guess API.
 * @param  num   your guess
 * @return 	     -1 if num is higher than the picked number
 *			      1 if num is lower than the picked number
 *               otherwise return 0
 * int guess(int num);
 */

class Solution
{
public:
    int guessNumber(int n)
    {
        int begin = 1, end = n, mid, ans;
        while (begin < end)
        {
            // mid = (begin + end) / 2;
            mid = begin + (end - begin) / 2;
            if (guess(mid) == -1)
            {
                end = mid - 1;
            }
            else if (guess(mid) == 1)
            {
                begin = mid + 1;
            }
            else
                return mid;
        }
        return begin;
    }
};
// @lc code=end

结果:

在这里插入图片描述

复杂度分析:

时间复杂度:O(logn),时间复杂度即为二分的次数,每次二分我们将区间的长度减小一半,直至区间长度为1时二分终止,而区间初始长度为n,因此二分次数为O(logn)。

空间复杂度:O(1)。

LeetCode的第374题“猜数字游戏”(Guess Number Higher or Lower)中,玩家和计算机进行一种简单的猜数字游戏。玩家需要猜测一个由计算机随机生成的1到n之间的整数,如果玩家猜的数字太小,计算机会提示“太低”,如果玩家猜的数字太大,计算机则提示“太高”。玩家有最多次数限制来猜测这个数字。 C++中可以使用回溯法(Backtracking)策略来解决这个问题。基本步骤如下: 1. 定义一个递归函数,接受当前猜测的数字、剩余的最大猜测次数以及已尝试过的数字范围。 2. 在函数开始时,设置一个标志变量,表示当前猜测的是最后一次机会。然后从剩余的数字范围内随机选择一个数字作为猜测。 3. 检查猜测的数字与实际数字的关系,如果是正确的,则返回胜利;如果太小,递归地调用函数并减去1次机会;如果太大,直接返回失败。 4. 在所有猜测机会用完之前,继续尝试新的数字,直到找到正确答案或者机会耗尽。 以下是简化的C++代码示例: ```cpp #include <vector> #include <ctime> int guessNumber(int n, vector<int>& guesses) { srand(time(0)); // 初始化随机种子 int target = rand() % (n + 1); // 生成1到n之间的随机数 int attempts = guesses.size(); // 最大尝试次数等于已给出的猜测次数 bool lastChance = false; for (int i = 0; i <= attempts && !lastChance; ++i) { int guess = guesses[i]; // 使用已知的猜测值 if (guess == target) { return i + 1; // 胜利,返回猜测次数 } else if (guess < target) { cout << "太低了 (" << guess << ")"; lastChance = i == attempts - 1; // 如果这是最后的猜测,标记为最后一次机会 } else { // guess > target cout << "太高了 (" << guess << ")"; lastChance = true; } } return -1; // 如果超过最大次数仍未能猜中,返回-1 } // 示例调用 int main() { vector<int> guesses = {2, 3, 5}; // 给出已有的猜测值 cout << guessNumber(10, guesses); return 0; } ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

UestcXiye

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值