• Java语法基础案例(二)


    目录

    案例六:抢红包

    案例七:找素数

    方法一:

    方法二:

    方法三:

    案例八:实现双色球

    关于本项目所用所有方法的解释:


    案例六:抢红包

    一个大V直播时发起了抢红包活动,分别有: 9、666、 188、520、 99999五个红包。请模拟粉丝来抽奖,按照先来先得,随机抽取,抽完即止,注意:一个红包只能被抽一-次,先抽或后抽哪一个红包是随机的。

    方法:写个for循环控制抽奖5次,每次抽奖,都从数组中随机找出一个金额,如果该金额不是0,则代表抽中,接着用0替换该位置处的金额,然后继续下一个粉丝的抽奖;如果抽中的金额发现是0,代表该位置处的红包之前被别人抽走了,则从新从数组中随机找出一个金额,继续判断!直至抽中的金额不是0!

    代码:

    1. package com.itheima;
    2. import java.util.Random;
    3. import java.util.Scanner;
    4. public class Test6 {
    5. public static void main(String[] args) {
    6. int[] moneys={9,66,188,520,99999};
    7. start(moneys);
    8. }
    9. public static void start(int[] moneys){
    10. //假设money=[9,66,188,520,99999]
    11. Scanner sc=new Scanner(System.in);
    12. Random r=new Random();//随机数对象
    13. //定义一个for循环,控制抽奖五次
    14. for (int i = 1; i <= 5; i++) {
    15. System.out.println("请您输入任意内容进行抽奖");
    16. sc.next();//等待用户输入内容,回车才往下走
    17. //为当前粉丝随机一个红包出来
    18. while (true) {//除非抽到不等于0的红包,否则一直抽
    19. int index = r.nextInt(moneys.length);//获得0-4的随机索引
    20. int money = moneys[index];//将对应索引的钱取出来
    21. //判断这个红包不为0
    22. if (money != 0) {
    23. System.out.println("恭喜您,您抽中了红包:" + money + "元");
    24. moneys[index] = 0;
    25. break;//结束这次抽奖
    26. }
    27. }
    28. }
    29. System.out.println("活动结束");
    30. }
    31. }

     

    案例七:找素数

    素数:除了1和它本身,不能被其他正整数整除就叫素数,比如3,7就是素数,9,21不是素数

    方法一:

    方法内部的实现逻辑:使用for循环来产生如101到200之间的每个数;每拿到一个数,判断该数是否是素数;判断规则是:从2开始遍历到该数的一半的数据,看是否有数据可以整除它,有则不是素数,没有则是素数;根据判定的结果来决定是否输出这个数据( 是素数则输出) ;最后还需要统计素数的个数并返回。

    代码:

    1. package com.itheima;
    2. public class Test7 {
    3. public static void main(String[] args) {
    4. System.out.println("当前素数的个数是"+search(101, 200));
    5. }
    6. public static int search(int start, int end) {
    7. int count = 0;
    8. //假设start=101 end=200
    9. for (int i = start; i <= end; i++) {
    10. boolean flag = true;
    11. for (int j = 2; j <= i / 2; j++) {
    12. if (i % j == 0) {
    13. flag = false;
    14. break;
    15. }
    16. }
    17. if (flag) {
    18. System.out.println(i);
    19. count++;
    20. }
    21. }
    22. return count;
    23. }
    24. }

    方法二:

    每当i%j==0时,这个数就已经不是素数了,没有向下循环的必要,而break和continue只能结束当前循环,所以我们需要为外部循环指定一个标签,从而直接跳出外部循环进行下一个数字的判断

    代码

    1. package com.itheima;
    2. public class Test7 {
    3. public static void main(String[] args) {
    4. System.out.println("当前素数的个数是"+search(101, 200));
    5. }
    6. public static int search(int start, int end) {
    7. int count = 0;
    8. Out://为外部循环指定标签
    9. //假设start=101 end=200
    10. for (int i = start; i <= end; i++) {
    11. for (int j = 2; j <= i / 2; j++) {
    12. if (i % j == 0) {
    13. continue Out;//直接跳出外部循环
    14. }
    15. }
    16. count++;
    17. System.out.println(i);
    18. }
    19. return count;
    20. }
    21. }

     

    方法三:

    直接将判断素数的过程定义为一个方法,通过判断方法是否true来输出素数并计数

    1. package com.itheima;
    2. public class Test7 {
    3. public static void main(String[] args) {
    4. System.out.println("当前素数的个数是"+search(101, 200));
    5. }
    6. public static int search(int start, int end) {
    7. int count=0;
    8. for (int i = start; i <=end ; i++) {
    9. if (check(i)){
    10. System.out.println(i);
    11. count++;
    12. }
    13. }
    14. return count;
    15. }
    16. public static boolean check(int data){
    17. for (int i = 2; i
    18. if (data%i==0){
    19. return false;
    20. }
    21. }
    22. return true;
    23. }
    24. }

     

    案例八:实现双色球

    模拟双色球:业务分析,用户投注一组号码

     

    设计步骤:

    1.让用户投注一组号码,并返回用户投注的号码

    2.系统随机一组中奖号码,并返回这组中奖号码

    3.传入两组号码,用来判断用户投注号码的中奖情况,并输出

    代码:

    1. package com.itheima;
    2. import java.util.Random;
    3. import java.util.Scanner;
    4. public class Test8 {
    5. public static void main(String[] args) {
    6. int[] userNumbers=userSelectNumbers();
    7. System.out.println("您投注的号码:");
    8. printArray(userNumbers);
    9. int[] luckNumbers=createLuckNumbers();
    10. System.out.println("中奖的号码:");
    11. printArray(luckNumbers);
    12. judge(userNumbers,luckNumbers);
    13. }
    14. public static void printArray(int[] arr){//输出数组
    15. System.out.print("[");
    16. for (int i = 0; i < arr.length; i++) {
    17. System.out.print(i==arr.length-1?arr[i]:arr[i]+",");//判断循环已经到达数组的最后一个位置,如果到达则直接打印数组中的数,如果没到则打印的数字后加一个逗号
    18. }
    19. System.out.println("]");
    20. }
    21. public static int[] userSelectNumbers() {//此方法用于让用户投注一组号码并返回
    22. int[] numbers = new int[7];//前六个是红球最后一个是蓝球
    23. Scanner sc = new Scanner(System.in);
    24. for (int i = 0; i < numbers.length - 1; i++) {
    25. while (true) {
    26. System.out.println("请您输入第" + (i + 1) + "个红球号码(1-33之间,不难重复)");
    27. int number = sc.nextInt();
    28. if (number < 1 || number > 33) {//判断号码是否在1-33之间
    29. System.out.println("对不起,您输入的红球号码不在1-33之间,请确认!");
    30. } else {
    31. if (exist(numbers, number)) {//判断号码是否重复
    32. System.out.println("对不起,您当前输入的红球号码与前面的号码重复了,请确认!");
    33. } else {
    34. numbers[i] = number;
    35. break;//结束当前死循环
    36. }
    37. }
    38. }
    39. }
    40. //投注最后一个蓝球号码
    41. while (true) {
    42. System.out.println("请您输入最后一个蓝球号码(1-16)");
    43. int number = sc.nextInt();
    44. if (number < 1 || number > 16) {
    45. System.out.println("对不起,您输入的蓝球号码范围不对哦!");
    46. } else {
    47. numbers[6] = number;
    48. break;//蓝球号码录入成功,结束死循环
    49. }
    50. }
    51. return numbers;
    52. }
    53. public static boolean exist(int[] numbers, int number) {//判断number这个数字是否在numbers这个数组中存在,也就是判断输入的数字是否重复
    54. for (int i = 0; i < numbers.length; i++) {
    55. if (numbers[i]==0){
    56. break;
    57. }
    58. if (numbers[i] == number) {
    59. return true;
    60. }
    61. }
    62. return false;
    63. }
    64. public static int[] createLuckNumbers(){//随机中奖号码
    65. int[] numbers=new int[7];
    66. Random r=new Random();
    67. for (int i = 0; i < numbers.length-1; i++)
    68. while (true) {
    69. {
    70. //为当前位置随机一个红球号码存入 1-33==>-1==>(0-32)+1
    71. int number=r.nextInt(33)+1;
    72. //判断这个号码是否之前出现过(红球号码不难重复)
    73. if (!exist(numbers,number)){
    74. numbers[i]=number;
    75. break;//结束死循环
    76. }
    77. }
    78. }
    79. //随机一个蓝球号码
    80. numbers[6]=r.nextInt(16)+1;
    81. return numbers;
    82. }
    83. public static void judge(int[] userNumbers,int[] luckNumbers){//判断用户的中奖情况
    84. //分别定义2个变量用于记住红球命中了几个以及蓝球命中了几个
    85. int redBall=0;
    86. int blueBall=0;
    87. //先判断红球命中的数量
    88. for (int i = 0; i < userNumbers.length-1; i++) {
    89. for (int j = 0; j < luckNumbers.length-1; j++) {
    90. if (userNumbers[i]==luckNumbers[j]){
    91. redBall++;
    92. break;
    93. }
    94. }
    95. }
    96. //判断蓝球是否命中
    97. blueBall=userNumbers[6]==luckNumbers[6]?1:0;
    98. System.out.println("您命中的红球数量是:"+redBall+"个");
    99. System.out.println("您命中的蓝球数量是:"+blueBall+"个");
    100. if (redBall==6&&blueBall==1){
    101. System.out.println("恭喜您,中奖1000万,不用当程序员了");
    102. }
    103. else if (redBall==6&&blueBall==0){
    104. System.out.println("恭喜您,中奖500万,不用担心裁员了");
    105. }
    106. else if (redBall==5&&blueBall==1){
    107. System.out.println("恭喜您,中奖3000元,可以出去吃顿小龙虾了");
    108. }
    109. else if (redBall==5&&blueBall==0||redBall==4&&blueBall==1){
    110. System.out.println("恭喜您中奖200元");
    111. }
    112. else if (redBall==4&&blueBall==0||redBall==3&&blueBall==1){
    113. System.out.println("中了10元");
    114. }
    115. else if (redBall==3&&blueBall==1){
    116. System.out.println("中了5元");
    117. }else {
    118. System.out.println("谢谢惠顾~");
    119. }
    120. }
    121. }

     

    关于本项目所用所有方法的解释:

    public static void printArray(int[] arr){:输出数组

    通过遍历数组输出数组,需要注意的点是判断输出的数字是否已经到达了数组的最后一个位置,如果是则不需要加逗号了

    public static int[] userSelectNumbers():使用户输入号码

    此方法用于让用户投注一组号码并返回,红球与蓝球分开输入,红球要6个,在数组的位置是numbers.length - 1及之前的,需要注意判断输入的数字是否在1-33之间已经是否重复,符合要求就存入数组,蓝球则直接定位到数组下标为6的地方,其余注意的地方与红球相同,特别要注意这里所用的死循环的秒处

    public static boolean exist(int[] numbers, int number):判断重复

    判断number这个数字是否在numbers这个数组中存在,也就是判断输入的数字是否重复,其中

    1. if (numbers[i]==0){
    2. break;
    3. }

     的应用使代码更加简洁,减去了多余的无用的运行

    public static int[] createLuckNumbers():随机中奖号码,与用户输入时类似,唯一需要注意的是以为想让系统随机1-33之间的数,所以用到了减加法,1-33==>-1>==>(0-32)+1

    r.nextInt(33)+1;即可随机1-33之间的数字

    r.nextInt(16)+1;即可随机1-16之间的数字

    public static void judge(int[] userNumbers,int[] luckNumbers):判断用户的中奖情况,使用嵌套循环数组遍历判断红球的命中情况,对于判断奖项问题只是纯粹的if...else if问题。

  • 相关阅读:
    分布式应用开发的核心技术系列之——基于TCP/IP的原始消息设计
    数据安全与个人隐私:美国人的焦虑与变化
    SSH登录引起配置文件多次生效、应用程序多次启动问题
    IDEA 调试远程服务
    为什么要在电影院装监控?有什么作用?
    吴恩达2022机器学习专项课程C2W2:实验SoftMax
    支付宝现金红包源码demo示例
    SpringBoot中过滤器与拦截器的区别
    打包和部署Java应用程序:Maven和Shell脚本的实用方法
    C/C++数字与字符串互相转换
  • 原文地址:https://blog.csdn.net/m0_73770225/article/details/133801579