4、Java——循环案例代码详解(1)

简介: 4、Java——循环案例代码详解(1)

案例一

       实现双色球的彩票功能。规则:从36个红球中随机选择不重复的6个数,从15个篮球中随机选择1个组成一注彩票。可以选择买多注。

public static void main(String[] args) {
  Scanner sc=new Scanner(System.in);
  System.out.println("请选择买几注:");
  int duoZhu=sc.nextInt();
        //多注彩票号码循环
  for (int k = 1; k <= duoZhu; k++) {
            //定义一个int数组,来存放7个彩票号码;        
    int[] redNums=new int[7];
    boolean repeat=false;
            //36个红球中随机出6个不同数字的循环
    for (int i = 0; i <6; i++) {
                //存到数组中去
    redNums[i]=(int)(Math.random()*35+1);
    if(i>0){
      for (int j = 0; j < i; j++) {
                        //新获取的随机数跟数组中已有的随机数作比较,得到repeat的bool值
      if(redNums[i]==redNums[j]){
        repeat=true;
        break;
      }
      }
    }
                //如果repeat=true;说明有重复的,则需要重新产生随机数
    if(repeat==true){
      redNums[i]=(int)(Math.random()*35+1);
    }
    }
            //数组中的第七个数从篮球的15个中随机产生
    redNums[6]=(int)(Math.random()*14+1);
    System.out.println("您的第"+k+"注彩票号码为:");
            //循环打印出七个彩票号码
    for (int i = 0; i < redNums.length; i++) {
    System.out.print(redNums[i]+"\t");
    }
    System.out.println();
  }
  }

运行效果:



2.png

案例二

       输出一个整数的二进制数、八进制数、十六进制数。


public static void main(String[] args) {
  String numS1="";
  Scanner sc=new Scanner(System.in);
  System.out.println("请输入一个整数:");
  int num=sc.nextInt();
  System.out.println("这个整数的二进制数:");
  for (int i = num; i > 0; i/=2) {
    numS1=i%2+numS1;
  }
  System.out.println(numS1);
        //打印完二进制后,清空numS1的内容
  numS1="";
  System.out.println("这个整数的八进制数:");
  for (int i = num; i > 0; i/=8) {
    numS1=i%8+numS1;
  }
  System.out.println(numS1);
        //打印完二进制后,清空numS1的内容
  numS1="";
  System.out.println("这个整数的十六进制数:");
  String s16="";
  System.out.println("这个整数的八进制数:");
  for (int i = num; i > 0; i/=16) {
    int z16=i%16;
    switch (z16) {
    case 10:
    s16="A";
    break;
    case 11:
    s16="B";
    break;
    case 12:
    s16="C";
    break;
    case 13:
    s16="D";
    break;
    case 14:
    s16="E";
    break;
    case 15:
    s16="F";
    break;
    default:
    s16=String.valueOf(z16);
    break;
    }
    numS1=s16+numS1;
  }
  System.out.println(numS1);
  }


运行效果:

1.gif


案例三

       随机产生一个字符,判断:如果为大写字母则输出“大写字母”;如果为小写字母则输出“小写字母”;否则怎输出“其他字符”;


public static void main(String[] args) {
  char zm=(char)(Math.random()*('z'-'A')+'A');
  System.out.println(zm);
  if(zm>='A'&&zm<='Z'){
    System.out.println("大写字母");
  }else if(zm>='a'&&zm<='z'){
    System.out.println("小写字母");
  }else{
    System.out.println("其他字符");
  }
  }

运行效果:

3.png

2.png

1.gif



案例四

       求两个整数的最大公约数和最小公倍数


       解题思路:先求最大公约数,用辗转相除法求,具体用法如下:


               例如,求(319,377):


                               ∵ 319÷377=0(余319)


                               ∴(319,377)=(377,319);


                               ∵ 377÷319=1(余58)


                               ∴(377,319)=(319,58);


                               ∵ 319÷58=5(余29)


                               ∴ (319,58)=(58,29);


                               ∵ 58÷29=2(余0)


                               ∴ (58,29)= 29;


                               ∴ (319,377)=29。


       下面代码中的do循环操作就是用的此方法实现的。


       最小公倍数:a,b的最大公约数记为(a,b)。关于最小公倍数与最大公约数,我们有这样的定理:(a,b)x[a,b]=ab(a,b均为整数)。


运行效果:

1.gif



案例五

       将100元兑换为1元、5元、10元的零钱,请问有多少种兑换方法?

public static void main(String[] args) {
  int count=0;
  for (int i = 0; i <=100; i++) {
    for (int j = 0; j <= 100; j+=5) {
    for (int k = 0; k <= 100; k+=10) {
      if(i+j+k==100){
      count++;
      }
    }
    }
  }
  System.out.println("将100元兑换为1元、5元、10元的零钱的兑换方法有"+count+"种。");
  }

运行效果:

1.gif

相关文章
JBoltAI 框架完整实操案例 在 Java 生态中快速构建大模型应用全流程实战指南
本案例基于JBoltAI框架,展示如何快速构建Java生态中的大模型应用——智能客服系统。系统面向电商平台,具备自动回答常见问题、意图识别、多轮对话理解及复杂问题转接人工等功能。采用Spring Boot+JBoltAI架构,集成向量数据库与大模型(如文心一言或通义千问)。内容涵盖需求分析、环境搭建、代码实现(知识库管理、核心服务、REST API)、前端界面开发及部署测试全流程,助你高效掌握大模型应用开发。
105 5
Java 学习路线规划及项目案例中的技术栈应用解析
内容包括:**Java 17核心特性**(如sealed class、record)与模块化开发;Spring Boot 3 + Spring Cloud微服务架构,涉及响应式编程(WebFlux)、多数据库持久化(JPA、R2DBC、MongoDB);云原生技术**如Docker、Kubernetes及CI/CD流程;性能优化(GraalVM Native Image、JVM调优);以及前后端分离开发(Vue 3、Spring Boot集成)。通过全栈电商平台项目实战,掌握从后端服务(用户、商品、订单)到前端应用(Vue 3、React Native)的全流程开发。
61 9
大数据大厂之MySQL数据库课程设计:揭秘MySQL集群架构负载均衡核心算法:从理论到Java代码实战,让你的数据库性能飙升!
本文聚焦 MySQL 集群架构中的负载均衡算法,阐述其重要性。详细介绍轮询、加权轮询、最少连接、加权最少连接、随机、源地址哈希等常用算法,分析各自优缺点及适用场景。并提供 Java 语言代码实现示例,助力直观理解。文章结构清晰,语言通俗易懂,对理解和应用负载均衡算法具有实用价值和参考价值。
大数据大厂之MySQL数据库课程设计:揭秘MySQL集群架构负载均衡核心算法:从理论到Java代码实战,让你的数据库性能飙升!
【Java实例-简易计算机】使用Java实现简单的计算机案例
一个简单的Java案例——“简易计算器”,帮助编程新手快速上手。通过实现用户输入、基本逻辑运算和结果输出,学习者可以掌握变量声明、Scanner对象使用、控制流语句等关键知识点。文章分为设计思路、关键知识点、完整代码和测试运行四个部分。
94 9
【Java实例-简易计算机】使用Java实现简单的计算机案例
Java 面试资料中相关代码使用方法与组件封装方法解析
这是一份详尽的Java面试资料代码指南,涵盖使用方法与组件封装技巧。内容包括环境准备(JDK 8+、Maven/Gradle)、核心类示例(问题管理、学习进度跟踪)、Web应用部署(Spring Boot、前端框架)、单元测试及API封装。通过问题库管理、数据访问组件、学习进度服务和REST接口等模块化设计,帮助开发者高效组织与复用功能,同时支持扩展如用户认证、AI推荐等功能。适用于Java核心技术学习与面试备考,提升编程与设计能力。资源链接:[点此下载](https://pan.quark.cn/s/14fcf913bae6)。
62 6
Java 面试资料中相关代码使用方法与组件封装方法解析
Java 生态大模型应用开发全流程实战案例与技术路径终极对决
在Java生态中开发大模型应用,Spring AI、LangChain4j和JBoltAI是三大主流框架。本文从架构设计、核心功能、开发体验、性能扩展性、生态社区等维度对比三者特点,并结合实例分析选型建议。Spring AI适合已有Spring技术栈团队,LangChain4j灵活性强适用于学术研究,JBoltAI提供开箱即用的企业级解决方案,助力传统系统快速AI化改造。开发者可根据业务场景和技术背景选择最适合的框架。
95 2
Java技术栈揭秘:Base64加密和解密文件的实战案例
以上就是我们今天关于Java实现Base64编码和解码的实战案例介绍。希望能对你有所帮助。还有更多知识等待你去探索和学习,让我们一同努力,继续前行!
121 5
校招 Java 面试常见知识点及实战案例全解析
本文全面解析了Java校招面试中的常见知识点,涵盖Java新特性(如Lambda表达式、、Optional类)、集合框架高级应用(线程安全集合、Map性能优化)、多线程与并发编程(线程池配置)、JVM性能调优(内存溢出排查、垃圾回收器选择)、Spring与微服务实战(Spring Boot自动配置)、数据库与ORM框架(MyBatis高级用法、索引优化)、分布式系统(分布式事务、缓存应用)、性能优化(接口优化、高并发限流)、单元测试与代码质量(JUnit 5、Mockito、JaCoCo)以及项目实战案例(电商秒杀系统、社交消息推送)。资源地址: [https://pan.quark.cn/s
83 4
基于Java 17 + Spring Boot 3.2 + Flink 1.18的智慧实验室管理系统核心代码
这是一套基于Java 17、Spring Boot 3.2和Flink 1.18开发的智慧实验室管理系统核心代码。系统涵盖多协议设备接入(支持OPC UA、MQTT等12种工业协议)、实时异常检测(Flink流处理引擎实现设备状态监控)、强化学习调度(Q-Learning算法优化资源分配)、三维可视化(JavaFX与WebGL渲染实验室空间)、微服务架构(Spring Cloud构建分布式体系)及数据湖建设(Spark构建实验室数据仓库)。实际应用中,该系统显著提升了设备调度效率(响应时间从46分钟降至9秒)、设备利用率(从41%提升至89%),并大幅减少实验准备时间和维护成本。
63 0
|
20天前
|
Java 集合容器实操技巧与案例详解
本教程基于Java 8+新特性和现代开发实践,深入讲解Java集合容器的实操技巧。通过具体场景演示Stream API数据处理、ConcurrentHashMap并发控制、LinkedHashMap实现LRU缓存、TreeSet自定义排序等高级特性。同时涵盖computeIfAbsent优化操作、EnumMap专用集合使用、集合统计与运算(交集、并集、差集)等内容。代码示例丰富,助力掌握高效编程方法。[点击获取完整代码](https://pan.quark.cn/s/14fcf913bae6)。
26 0

热门文章

最新文章

AI助理

你好,我是AI助理

可以解答问题、推荐解决方案等

登录插画

登录以查看您的控制台资源

管理云资源
状态一览
快捷访问