java实现简单的猜数字小游戏

 更新时间:2021年03月31日 17:13:48   作者:buptwhq  
这篇文章主要为大家详细介绍了java实现简单猜数字小游戏,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

本文实例为大家分享了java实现简单的猜数字的具体代码,供大家参考,具体内容如下

题目描述:

猜数字(又称 Bulls and Cows )是一种古老的的密码破译类益智类小游戏,起源于20世纪中期,一般由两个人或多人玩,也可以由一个人和电脑玩。通常由两个人玩,一方出数字,一方猜。出数字的人要想好一个没有重复数字的4个数,不能让猜的人知道。猜的人就可以开始猜。每猜一个数字,出数者就要根据这个数字给出nAmB,其中A前面的数字n表示数字正确且位置也正确的数的个数,而B前的数字m表示数字正确但位置不正确的数的个数。如正确答案为 5234,而猜的人猜 5346,则是 1A2B,其中有一个5的位置对了,记为1A,而3和4这两个数字对了,而位置没对,因此记为 2B,合起来就是 1A2B。接着猜的人再根据出题者的几A几B继续猜,直到猜中(即 4A0B)为止。

程序要求:

1、满足题意 2、输入数字的合法性3、输出总猜测次数

代码

package Practice;
// 猜数字 (Bulls and cows)
import java.util.Scanner;

public class Day0322 {
 public static void main(String[] args) {
 Scanner scanner = new Scanner(System.in);
 // 产生0000~9999的随机数
 double r = Math.random();
 int res = (int)(r * 8999 + 1000);

 int flag = 0;
 // 合法性检查,判断存在重复数字
 while(flag == 0)
 {
  int[] check = new int[10];
  for(int i = 0; i < 10; i ++ ) check[i] = 0;

  check[res / 1000] += 1;check[(res / 100) % 10] += 1;
  check[(res / 10) % 10] += 1;check[res % 10] += 1;

  for(int i = 0; i < 10; i ++ )
  if(check[i] >= 2) {
   r = Math.random();
   res = (int)(r * 8999 + 1000);
   flag = 0;
   break;
  }
  else flag = 1;
 }

 // 0000~9999
 System.out.println("答案: " + res);

 int input = -1;
 int idx = 0;
 int times = 0;
 while(input != res)
 {
  System.out.print("请输入你猜的数字: ");
  input = scanner.nextInt();
  int inputcopy = input;

  if(input < 0)
  {
  System.out.println("您输入的数字不是四位数!");
  times ++;
  continue;
  }
  int t = 0;
  // 输入数字为4位数,合法性检查
  while(inputcopy != 0)
  {
  inputcopy /= 10;
  t ++;
  }
  if(t != 4)
  {
  System.out.println("您输入的数字不是四位数!");
  times ++;
  continue;
  }

  int n = 0, m = 0;// nAmB

  if(input == res) break;
  // 输入的各个位数
  int[] a = new int[4];
  a[0] = input / 1000;a[1] = (input / 100) % 10;
  a[2] = (input / 10) % 10; a[3] = (input) % 10;
  // 答案的各个位数
  int[] ans = new int[4];
  ans[0] = res / 1000;ans[1] = (res / 100) % 10;
  ans[2] = (res / 10) % 10; ans[3] = (res) % 10;

  for(int i = 0; i < 4; i ++)
  {
  if(ans[i] == a[i]) n += 1; // A的数量
  for(int j = 0; j < 4; j ++){// B的数量
   if(ans[j] == a[i] && j != i) m += 1;
  }
  }
  System.out.print((++ idx) + ": " + n + "A" + m + "B");
  System.out.println();
  times ++;

 }
 if(input == res){
  times ++;
  System.out.println("4A0B");
  System.out.println("你很厉害啊!");
  System.out.println("猜测次数: " + times);
 }

 }

}

运行效果

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

相关文章

  • Spring核心容器之ApplicationContext上下文启动准备详解

    Spring核心容器之ApplicationContext上下文启动准备详解

    这篇文章主要介绍了Spring核心容器之ApplicationContext上下文启动准备详解,ApplicationContext 继承自 BeanFactory ,其不仅包含 BeanFactory 所有功能,还扩展了容器功能,需要的朋友可以参考下
    2023-11-11
  • Java中的static--静态变量你了解吗

    Java中的static--静态变量你了解吗

    Java 中被 static 修饰的成员称为静态成员或类成员。它属于整个类所有,而不是某个对象所有,即被类的所有对象所共享。静态成员可以使用类名直接访问,也可以使用对象名进行访问,.下面我们来详细了解一下吧
    2021-09-09
  • Java使用Spire.Presentation for Java将PPT转换为PDF

    Java使用Spire.Presentation for Java将PPT转换为PDF

    文章介绍Java开发者使用Spire.PresentationforJava将PPT转换为PDF,支持跨平台兼容、PDF/A标准、加密、隐藏幻灯片和自定义页面大小等高级功能,满足文档分发、归档与安全需求
    2025-10-10
  • Java通俗易懂系列设计模式之策略模式

    Java通俗易懂系列设计模式之策略模式

    这篇文章主要介绍了Java通俗易懂系列设计模式之策略模式,对设计模式感兴趣的同学,一定要看一下
    2021-04-04
  • Mybatis-Plus的多数据源你了解吗

    Mybatis-Plus的多数据源你了解吗

    这篇文章主要为大家详细介绍了Mybatis-Plus的多数据源,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下,希望能够给你带来帮助
    2022-03-03
  • idea 程序打包 jar 发布的配置方法

    idea 程序打包 jar 发布的配置方法

    文章介绍了如何在IntelliJ IDEA中配置和构建JAR包,包括设置Artifact、选择MainClass、配置输出路径等步骤,并提供了发布JAR包的命令,感兴趣的朋友跟随小编一起看看吧
    2024-11-11
  • HttpClient的RedirectStrategy重定向处理核心机制

    HttpClient的RedirectStrategy重定向处理核心机制

    这篇文章主要为大家介绍了HttpClient的RedirectStrategy重定向处理核心机制源码解读,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2023-10-10
  • SpringBoot整合Redis的实现示例

    SpringBoot整合Redis的实现示例

    本文主要介绍了SpringBoot整合Redis的实现示例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2023-01-01
  • spring控制事务的三种方式小结

    spring控制事务的三种方式小结

    这篇文章主要介绍了spring控制事务的三种方式小结,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2021-10-10
  • Java中的接口及其应用场景解读

    Java中的接口及其应用场景解读

    这篇文章主要介绍了Java中的接口及其应用场景解读,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2023-05-05

最新评论