log2N
public static void main(String[] args) {
int n = 3;
for (int i = 1; i <= 10; i++) {
System.out.println("输入:"+i);
turns(i, 1, 10);
}
}
private static int turns(int n, int low, int high) {
int turns = 0;
int guss = 0;
while (high - low >= 2) {
turns++;
int mid = (low + high) / 2;
guss = mid;
System.out.print(" 第"+turns+"次,我猜:"+guss);
if (mid == n) {
System.out.println(" 猜对了 end");
return turns;
} else if (mid < n) {
System.out.print(" 猜低了");
low = mid + 1;
} else {
System.out.print(" 猜高了");
high = mid - 1;
}
}
System.out.println("第"+(1 + turns)+"次"+" "+(guss+1) +" or "+(guss-1) +" end");
return 1 + turns;
}
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】凌霞软件回馈社区,博客园 & 1Panel & Halo 联合会员上线
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步