[LeetCode]--374. Guess Number Higher or Lower

本文介绍了如何玩Guess Game,玩家需要从1到n中猜测我选择的数字。每次猜测错误,会得到是更高还是更低的提示。解决这个问题可以利用二分查找算法,通过guess(int num) API获取(-1, 1, 0)的返回值来逐步缩小范围。" 132687598,18614638,拔河比赛人选选择算法,"['Python', '排序算法', '数据结构', '华为机试题']

We are playing the Guess Game. The game is as follows:

I pick a number from 1 to n. You have to guess which number I picked.

Every time you guess wrong, I’ll tell you whether the number is higher or lower.

You call a pre-defined API guess(int num) which returns 3 possible results (-1, 1, or 0):

-1 : My number is lower
 1 : My number is higher
 0 : Congrats! You got it!

Example:

n = 10, I pick 6.

Return 6.

思路就是二分查找法。

public int guessNumber(int n) {
        int low = 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; } ```
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值