当前位置:网站首页>【LeetCode每日一题】——374.猜数字大小
【LeetCode每日一题】——374.猜数字大小
2022-08-04 16:55:00 【IronmanJay】
一【题目类别】
- 二分查找
二【题目难度】
- 简单
三【题目编号】
- 374.猜数字大小
四【题目描述】
- 猜数字游戏的规则如下:
- 每轮游戏,我都会从 1 到 n 随机选择一个数字。 请你猜选出的是哪个数字。
- 如果你猜错了,我会告诉你,你猜测的数字比我选出的数字是大了还是小了。
- 你可以通过调用一个预先定义好的接口 int guess(int num) 来获取猜测结果,返回值一共有 3 种可能的情况(-1,1 或 0):
- -1:我选出的数字比你猜的数字小 pick < num
- 1:我选出的数字比你猜的数字大 pick > num
- 0:我选出的数字和你猜的数字一样。恭喜!你猜对了!pick == num
- 返回我选出的数字。
五【题目示例】
示例 1:
输入:n = 10, pick = 6
输出:6示例 2:
输入:n = 1, pick = 1
输出:1示例 3:
输入:n = 2, pick = 1
输出:1示例 4:
输入:n = 2, pick = 2
输出:2
六【题目提示】
- 1 < = n < = 2 31 − 1 1 <= n <= 2^{31} - 1 1<=n<=231−1
- 1 < = p i c k < = n 1 <= pick <= n 1<=pick<=n
七【解题思路】
- 主要还是二分查找的思路
- 因为是在1~n中查找(类似二分查找的下标,也就是范围),所以left为1,right为n
- 后面就是二分查找了,根据题目给的函数,判断比选的值大还是小,然后left和right做相应的变化
- 最后如果找到了相同的就直接返回,因为是在1~n中查找,值也是在1~n中,所以一定会找到的
八【时间频度】
- 时间复杂度: O ( l o g 2 N ) O(log_{2}N) O(log2N),其中 N N N题目给的元素大小
- 空间复杂度: O ( 1 ) O(1) O(1)
九【代码实现】
- Java语言版
package BinarySearch;
public class p374_GuessTheSizeOfTheNumber {
public static void main(String[] args) {
int res = guessNumber(10);
System.out.println("res = " + res);
}
public static int guessNumber(int n) {
int left = 1;
int right = n;
while (left <= right) {
int mid = left + (right - left) / 2;
int pick = guess(mid);
if (pick == 0) {
return mid;
} else if (pick == -1) {
right = mid - 1;
} else if (pick == 1) {
left = mid + 1;
}
}
return 0;
}
public static int guess(int num) {
int pick = 6;
if (num == pick) {
return 0;
} else if (num < pick) {
return 1;
} else {
return -1;
}
}
}
- C语言版
#include<stdio.h>
int guess(int num)
{
int pick = 6;
if (num == pick)
{
return 0;
}
else if (num < pick)
{
return 1;
}
else
{
return -1;
}
}
int guessNumber(int n)
{
int left = 1;
int right = n;
while (left <= right)
{
int mid = left + (right - left) / 2;
int pick = guess(mid);
if (pick == 0)
{
return mid;
}
else if (pick == 1)
{
left = mid + 1;
}
else if (pick == -1)
{
right = mid - 1;
}
}
return 0;
}
/*主函数省略*/
十【提交结果】
Java语言版

C语言版

边栏推荐
- LeetCode 0167. 两数之和 II - 输入有序数组
- 浙江数码代工M301H 免拆通刷_卡刷固件包(语音OK)
- 软件基础的理论
- GraphQL 入门与实践
- 生产环境重大bug,update加上索引字段会走索引进行更新?还是走全表扫描
- Analysis of the gourd baby
- Minecraft 服务器安装Forge 并添加Mod
- Mobile magic box CM201-1_CW_S905L2_MT7668_wire brush firmware package
- 多线程学习笔记-3.并发容器
- 罗振宇折戟创业板/ B站回应HR称用户是Loser/ 腾讯罗技年内合推云游戏掌机...今日更多新鲜事在此...
猜你喜欢

mysql学习笔记——利用动态SQL和Session变量实现一个公式或者计算器

Mobile magic box CM211-1_YS foundry _S905L3B_RTL8822C_wire brush firmware package

ping不通百度

移动百事通BesTV_R3300-L_S905L_8189_线刷固件包

How to convert an int attribute into a string in the json format returned by the Go language gin framework?

适配器模式

美容院管理系统有哪些促销方式?

软件基础的理论

Minecraft HMCL 第三方启动器使用教程

win11如何退出安全模式
随机推荐
跨链桥已成行业最大安全隐患 为什么和怎么办
从-99打造Sentinel高可用集群限流中间件
机器学习(十六):主成成分分析(PCA)
Mobile zte ZXV10 B860AV2. 1 - A_S905L2_MT7668_ wire brush the firmware package
SQL语言的分类以及数据库的导入
码蹄集 - MT2165 - 小码哥的抽卡之旅1
太一集团宣布全资收购火币旗下社交产品火信
MySQL 性能调优和优化技巧
华为应用市场“图章链接”功能上线 让APP分发突破机型壁垒
Unity Apple登录接入
15天升级打怪,成为虚拟时尚创作者
码蹄集 - MT2142 - 万民堂大厨
SAP ABAP SteammPunk 蒸汽朋克的最新进展 - 嵌入式蒸汽朋克
机器学习(十九):梯度提升回归(GBR)
MySQL学习之运算符
地理标志农产品需双重保护
手把手教你搭建一个Minecraft 服务器
AtCoder Beginner Contest 262 部分题解
博云入选Gartner中国云原生领域代表性厂商
机器学习(十一):KNN(K近邻)