Java猜数字案例

案例介绍:
我们在日常生活中,经常与朋友们玩猜数字的游戏,非常的有趣。现在我们通过java把这个猜数字游戏编写出来。
猜数字案例是要完成什么样的功能呢?顾名思义,这个游戏就是你出个数字、我来猜。
游戏操作如下:
后台预先生成一个1-100之间的随机数,用户键盘录入猜数字
如果猜对了,打印“恭喜您,答对了”
如果猜错了
猜大了:打印“sorry,您猜大了!”
猜小了:打印“sorry,您猜小了!”
直到数字猜到为止

在案例开始之前,我们先要学习如下知识点:
随机数类Random
选择结构if
循环结构while
3.2案例需求分析、
猜数字案例的需求如下:
后台预先生成一个1-100之间的随机数,用户键盘录入猜数字
如果猜对了,打印“恭喜您,答对了”
如果猜错了
猜大了:打印“sorry,您猜大了!”
猜小了:打印“sorry,您猜小了!”
直到数字猜到为止

我们经过分析,得出如下的分析结果:
1.通过Random类中方法nextInt(),生成一个1-100之间的随机数
2.输入猜的数字
3.通过while循环,进行猜数字对错判断
猜对,跳出循环,游戏结束
猜错了,根据结果,给出提示,接着猜数字,游戏继续
如果猜大了,打印sorry,您猜大了!继续下一次循环
如果猜小了,打印sorry,您猜小了!继续下一次循环

3.3实现代码步骤``

public class GuessNumber {
	public static void main(String[] args) {
		//1.通过Random类中方法nextInt(),生成一个1-100之间的随机数
		int randomNumber = new Random().nextInt(100);
		System.out.println("随机数已生成!");
		//2.输入猜的数字
		System.out.println("----请输入您猜的数字:----");
		Scanner sc = new Scanner(System.in);
		int enterNumber = sc.nextInt();
		//3.通过while循环,进行猜数字对错判断
		//猜对,跳出循环,游戏结束
		while(enterNumber != randomNumber){
			//猜错了,根据结果,给出提示,接着猜数字,游戏继续
			if(enterNumber>randomNumber) { 
				//如果猜大了,打印sorry,您猜大了!继续下一次循环
				System.out.println("sorry,您猜大了!继续下一次循环");
			}else {
				//如果猜小了,打印sorry,您猜小了!继续下一次循环
				System.out.println("sorry,您猜小了!继续下一次循环");
			}
			//输入猜的数字
			System.out.println("----请输入您猜的数字:----");
			enterNumber = sc.nextInt();
		}
		System.out.println("恭喜您,答对了!");
	}
}
根据提供的引用内容,我们可以看到其包含了Java数组排序和数组猜数字游戏案例的内容。因此,我们可以结合这两个内容来回答这个问题。 Java的快速排序是一种常用的排序算法,其基本思想是通过一趟排序将待排记录分隔成独立的两部分,其一部分记录的关键字均比另一部分记录的关键字小,然后再分别对这两部分记录继续进行排序,以达到整个序列有序的目的。 下面是一个使用Java实现快速排序的例子: ```java public class QuickSort { public static void quickSort(int[] arr, int left, int right) { if (left < right) { int i = left, j = right, x = arr[left]; while (i < j) { while (i < j && arr[j] >= x) { j--; } if (i < j) { arr[i++] = arr[j]; } while (i < j && arr[i] < x) { i++; } if (i < j) { arr[j--] = arr[i]; } } arr[i] = x; quickSort(arr, left, i - 1); quickSort(arr, i + 1, right); } } public static void main(String[] args) { int[] arr = {3, 1, 4, 1, 5, 9, 2, 6, 5, 3, 5}; quickSort(arr, 0, arr.length - 1); System.out.println(Arrays.toString(arr)); } } ``` 上述代码,我们定义了一个`quickSort`方法,该方法接收一个整型数组`arr`、一个整数`left`和一个整数`right`作为参数,其`left`和`right`分别表示待排序数组的左右边界。在方法,我们首先判断`left`是否小于`right`,如果是,则进行快速排序。具体实现过程如下: 1. 定义三个整型变量`i`、`j`和`x`,其`i`和`j`分别表示待排序数组的左右指针,`x`表示待排序数组的第一个元素。 2. 在循环,我们首先从右向左遍历数组,找到第一个小于`x`的元素,将其赋值给`arr[i]`,然后将`i`加1。接着从左向右遍历数组,找到第一个大于等于`x`的元素,将其赋值给`arr[j]`,然后将`j`减1。 3. 如果`i`小于`j`,则将`arr[j]`赋值给`arr[i]`,然后将`i`加1,`j`减1。 4. 当`i`等于`j`时,将`x`赋值给`arr[i]`。 5. 最后,递归调用`quickSort`方法,对左右两个子数组进行排序。 接下来,我们可以结合数组猜数字游戏案例来演示如何使用快速排序。在这个案例,我们需要生成一个长度为10的随机整数数组,并让用户猜测其的一个数字。每次猜测后,程序会告诉用户猜测的数字是大于还是小于目标数字,直到用户猜为止。 下面是一个使用Java实现的数组猜数字游戏案例: ```java import java.util.Arrays; import java.util.Random; import java.util.Scanner; public class GuessNumber { public static void main(String[] args) { int[] arr = new int[10]; Random random = new Random(); for (int i = 0; i < arr.length; i++) { arr[i] = random.nextInt(100); } quickSort(arr, 0, arr.length - 1); System.out.println(Arrays.toString(arr)); Scanner scanner = new Scanner(System.in); int target = arr[random.nextInt(10)]; System.out.println("猜一个0到99之间的数字:"); while (true) { int guess = scanner.nextInt(); if (guess == target) { System.out.println("恭喜你猜对了!"); break; } else if (guess < target) { System.out.println("猜小了,请继续猜:"); } else { System.out.println("猜大了,请继续猜:"); } } } public static void quickSort(int[] arr, int left, int right) { if (left < right) { int i = left, j = right, x = arr[left]; while (i < j) { while (i < j && arr[j] >= x) { j--; } if (i < j) { arr[i++] = arr[j]; } while (i < j && arr[i] < x) { i++; } if (i < j) { arr[j--] = arr[i]; } } arr[i] = x; quickSort(arr, left, i - 1); quickSort(arr, i + 1, right); } } } ``` 上述代码,我们首先生成一个长度为10的随机整数数组,并使用快速排序对其进行排序。然后,我们随机选择一个数组元素作为目标数字,并让用户猜测该数字。在循环,我们不断读取用户输入的数字,并与目标数字进行比较,直到用户猜为止。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值