【Java】循环语句练习
文章目录
- 1. 计算5的阶乘
- 2. 计算 1! + 2! + 3! + 4! + 5!
- 3. 数字9 出现的次数
- 4. 判定素数
- 5. 求1-100之间的素数
- 6. 求2个整数的最大公约数
- 7. 计算分数的值
- 8. 模拟登陆
- 9. 输出乘法口诀表
- 10. 求出0~999之间的所有“水仙花数”并输出
- 11. 猜数字游戏🙈
1. 计算5的阶乘
n! (阶乘),一个正整数的阶乘是所有小于及等于该数的正整数的积,并且0的阶乘为1。自然数n的阶乘写作n!,即n!=1×2×3×…×(n-1)×n。5! = 1×2×3×4x5。
- while循环实现
public class Test {//计算5的阶乘public static void main(String[] args) {int n = 1;int ret = 1;while(n<=5){ret *= n;n++;}System.out.println(ret);}
}
- for循环实现
public class Test {//计算5的阶乘public static void main(String[] args) {int ret = 1;for (int n = 1;n <= 5;n++){ret *= n;}System.out.println(ret);}
}

我们上一题学习了n阶乘的计算,这一题计算阶乘的和。阶乘的求和就是在计算阶乘的基础上再加一层循环。
2. 计算 1! + 2! + 3! + 4! + 5!
- while 循环实现
public class Test {//计算 1! + 2! + 3! + 4! + 5!public static void main(String[] args) {int i = 1;int sum = 0;//外层循环负责求阶乘的和while(i <= 5){int n = 1;int ret = 1;//内层循环负责完成求阶乘的细节while (n <= i){ret *= n;n++;}sum += ret;i++;}System.out.println("sum="+sum);}
}
- for 循环实现
public class Test {//计算 1! + 2! + 3! + 4! + 5!public static void main(String[] args) {int sum = 0;for (int i = 1;i <= 5;i++){int ret = 1;for(int n = 1;n <= i;n++){ret *= n;}sum += ret;}System.out.println("sum="+sum);}
}

3. 数字9 出现的次数
编写程序数一下 1到 100 的所有整数中出现多少个数字9
个位数为9的数字有9,19,29……99;个位数判断为 i % 10 == 9;
十位数为9的数字有91,92,93……99;十位数判断为 i % 10 == 9。
其中99出现了两次
public class Test {public static void main(String[] args) {int count = 0;for(int i = 0;i <= 100;i++){if(i % 10 == 9){count++;}if(i / 10 == 9){count++;}}System.out.println(count);}
}

4. 判定素数
给定一个数字,判定一个数字是否是素数。
素数是只能被 1 和它本身整除的数。也就是说能被 2 到 n-1 整除的数都不是素数。
import java.util.Scanner;public class Test {//判断一个数是不是素数public static void main(String[] args) {Scanner scanner = new Scanner(System.in);int n = scanner.nextInt();int i = 2;for (i = 2;i < n ; i++) {if(i % n == 0){System.out.println(i+"不是素数");}}if(i == n){System.out.println(i+"是素数");}}
}

5. 求1-100之间的素数
上一题我们是从键盘输入一个数,判断是否为素数,而这一题则是在上一题的基础上从键盘输入1-100的数,判断这些数中有哪些数是素数。
public class Test {public static void main(String[] args) {//打印1-100之间的素数Scanner scanner = new Scanner(System.in);int n = scanner.nextInt();for(int k = 1;k <= n;k++){int i = 2;for (i = 2;i < n ; i++) {if(k % i == 0){break;}}if(i == k){System.out.println(k+"是素数");}}}
}
- 优化1
public class Test {//k = a * b//16 = 1 * 16//16 = 2 * 8//16 = 4 * 4//其中一定会有一个乘数小于k/2,所以我们将判断条件改为i <= k/2效率则更高public static void main(String[] args) {//打印1-100之间的素数Scanner scanner = new Scanner(System.in);int n = scanner.nextInt();for(int k = 1;k <= n;k++){int i = 2;for (i = 2;i <= k/2 ; i++) {if(k % i == 0){break;}}if(i >k/2){System.out.println(k+"是素数");}}}
}
- 优化2
public class Test {//k = a * b//16 = 1 * 16//16 = 2 * 8//16 = 4 * 4//我们会发现一定会有一个值<=根号k//根号在java中需要调用Math.sqrt(k)public static void main(String[] args) {//打印1-100之间的素数Scanner scanner = new Scanner(System.in);int n = scanner.nextInt();for(int k = 1;k <= n;k++){int i = 2;for (i = 2;i <= Math.sqrt(k) ; i++) {if(k % i == 0){break;}}if(i > Math.sqrt(k)){System.out.println(k+"是素数");}}}
}

6. 求2个整数的最大公约数
给定两个数,求这两个数的最大公约数
例如:
输入:20 40
输出:20
public class Test {//辗转相除法求最大公约数public static void main(String[] args) {Scanner scanner = new Scanner(System.in);int a = scanner.nextInt();int b = scanner.nextInt();int tmp = a % b;while(tmp != 0){a = b;b = tmp;tmp = a % b;}System.out.println(b);}
}

7. 计算分数的值
计算1/1-1/2+1/3-1/4+1/5 …… + 1/99 - 1/100 的值。
public class Test {public static void main(String[] args) {double sum = 0;int flg = 1;for (int i = 1; i <= 100 ; i++) {sum = sum + 1.0/i * flg;flg = -flg;//正负交替}System.out.println(sum);}
}

8. 模拟登陆
编写代码模拟三次密码输入的场景。 最多能输入三次密码,密码正确,提示“登录成功”,密码错误, 可以重新输 入,最多输入三次。三次均错,则提示退出程序 。
字符串的比较不可以使用 == 而需要使用到 equals 库方法,equals方法是由 password 点出来的,password 是一个变量能点出一个方法是因为 password 是 string 类型的。
public class Test {//模拟登录public static void main(String[] args) {Scanner in = new Scanner(System.in);int count = 3;while (count != 0){System.out.println("请输入你的密码,你还有 "+ count +" 次机会!");String password = in.nextLine();if(password.equals("1234")){System.out.println("登录成功!");break;}else{System.out.println("密码错误!");count--;}}}
}

9. 输出乘法口诀表
输出n*n的乘法口诀表,n由用户输入。
public class Test {//九九乘法表public static void main(String[] args) {Scanner in = new Scanner(System.in);int n = in.nextInt();for (int i = 1; i <= n; i++) {for (int j = 1; j <= i; j++) {System.out.print(j+"*"+ i +" = " +j*i+" ");}System.out.println();}}
}

10. 求出0~999之间的所有“水仙花数”并输出
(“水仙花数”是指一个三位数,其各位数字的立方和确好等于该数
本身,如:153=1^3+5^3+3^3 ,则153是一个“水仙花数”。)
一位自幂数:独身数
三位自幂数:水仙花数
三位的水仙花数共有4个:153,370,371,407。
public class Test {//水仙花数//153 = 1^3 + 5^3 + 3^3public static void main(String[] args) {for (int i = 0; i < 999; i++) {int count = 0;//计算当前i 有几位数int tmp = i;while (tmp != 0) {count++;tmp = tmp / 10;}//count的值 是多少已经计算完成 i还是没有变的//计算i[tmp]的每一位tmp = i;int sum = 0;while (tmp != 0) {sum += Math.pow(tmp%10,count);tmp /= 10;}if(sum == i) {System.out.println(i);}}}
}


11. 猜数字游戏🙈
游戏规则:
系统自动生成一个随机整数(1-100), 然后由用户输入一个猜测的数字. 如果输入的数字比该随机数小, 提示 “猜小了”, 如果输入的数字比该随机数大, 提示 “猜大了” , 如果输入的数字和随机数相等, 则提示 “猜对了” 。
import java.util.Random;
import java.util.Scanner;
public class Test {//猜数字游戏public static void main(String[] args) {Random random = new Random();int randNum = random.nextInt(100);//[0,100)Scanner scanner = new Scanner(System.in);while (true){System.out.println("请输入你要猜的数字: ");int num = scanner.nextInt();if(num > randNum){System.out.println("猜大了!");}else if (num == randNum){System.out.println("猜对了!");break;}else{System.out.println("猜小了!");}}}
}
浅玩一下吧

本章到这里就结束啦,如果有哪里写的不好的地方,请指正。
如果觉得不错并且对你有帮助的话请给个三连支持一下吧!
Fighting!!!✊
相关文章:
【Java】循环语句练习
文章目录 1. 计算5的阶乘2. 计算 1! 2! 3! 4! 5!3. 数字9 出现的次数4. 判定素数5. 求1-100之间的素数6. 求2个整数的最大公约数7. 计算分数的值8. 模拟登陆9. 输出乘法口诀表10. 求出0~999之间的所有“水仙花数”并输出11. 猜数字游戏🙈 1. 计算5的…...
「Verilog学习笔记」非整数倍数据位宽转换24to128
专栏前言 本专栏的内容主要是记录本人学习Verilog过程中的一些知识点,刷题网站用的是牛客网 要实现24bit数据至128bit数据的位宽转换,必须要用寄存器将先到达的数据进行缓存。24bit数据至128bit数据,相当于5个输入数据第6个输入数据的拼接成一…...
2023亚太地区数学建模C题思路模型代码论文
C题的参考思路: 1,问题1的思路: 确定研究问题的主要指标体系(新能源电车的售出数量、安全性指标、充电桩数目、电池续 航里程等),收集指标的对应数据,检验数据是否服从正态性: 若服从正态分布: 0,可考虑优先采用“多元方差分析”模…...
苹果商城App上架指南在中发里查看
苹果商城App上架指引可以在app应用分发平台网站上查看。具体步骤如下: 登录苹果开发者网站。进入“Certificates, Identifiers & Profiles”选项。在页面左侧选择“App Store Connect”。点击“App Store Connect”页面顶部的“Developer Guide”。在左侧菜单中…...
Android 框架层AIDL 添加接口
文章目录 AIDL的原理构建AIDL的流程往冻结的AIDL中加接口 AIDL的原理 可以利用ALDL定义客户端与服务均认可的编程接口,以便二者使用进程间通信 (IPC) 进行相互通信。在 Android 中,一个进程通常无法访问另一个进程的内存。因此,为进行通信&a…...
ubuntu命令行下中文乱码怎么解决
大家好,今天来介绍ubuntu命令行中文乱码怎么解决(ubuntu中文文件名乱码)的问题,以下是渲大师小编对此问题的归纳和整理,感兴趣的来一起看看吧! ubuntu命令行下中文乱码怎么解决 我也呀见过这个问题 一. Ubuntu默认的中文字符编码 Ubuntu默认的中文字谈码符编码为zh_CN.UT…...
沈阳陪诊系统|陪诊软件开发功能
陪诊小程序的出现它可以帮助患者或家属解决就医过程中的各种问题。根据数据显示,2021年中国陪诊市场规模约为36.7亿元,预计到2025年将达到100亿元。同时,在医疗行业数字化转型的大背景下,陪诊微信小程序作为一种创新的医疗服务模式…...
Element-Plus 表格 el-table 如何支持分页多选
🚀 作者主页: 有来技术 🔥 开源项目: youlai-mall 🍃 vue3-element-admin 🍃 youlai-boot 🌺 仓库主页: Gitee 💫 Github 💫 GitCode 💖 欢迎点赞…...
网站被流量攻击了,该怎么处理
几乎每个网站都面临被攻击或者入侵的风险,无论是简单的博客论坛、投资平台、小型的独立电商网站还是动态电子商务平台都有被攻击的情况出现,只是或大或小,或多或少罢了 为什么网站会被攻击?黑客如何来入侵这些网站?如何才能有效保护我的网站不…...
配置特定 IP 地址走指定网关
公司有两个日常上网用的路由器,分别接不同的两条网线,虽然都是电信的,但是一条偶尔会抽风,我的 VPS 会连不上,也就是挂在上面的 SS 无法使用。恰好这根线是公司接台式机的,也就是说平时上班偶尔会无法科学上…...
Linux的基本指令(四)
目录 前言 时间相关的指令 date指令 时间戳 日志 时间戳转化为具体的时间 cal指令 find指令(十分重要) grep指令(行文本过滤工具) 学前补充 什么是打包和压缩? 为什么要打包和压缩? 怎么打包和…...
vue+elementui如何实现在表格中点击按钮预览图片?
效果图如上: 使用el-image-viewer 重点 : 引入 import ElImageViewer from "element-ui/packages/image/src/image-viewer"; <template><div class"preview-table"><el-table border :data"tableData" …...
LLaMA 2:开源的预训练和微调语言模型推理引擎 | 开源日报 No.86
facebookresearch/llama Stars: 36.0k License: NOASSERTION LLaMA 2 是一个开源项目,用于加载 LLaMA 模型并进行推理。 该项目的主要功能是提供预训练和微调后的 LLaMA 语言模型的权重和起始代码。这些模型参数范围从 7B 到 70B 不等。 以下是该项目的关键特性…...
01-AI大模型智能客服 V0.1「上」
你好,我是悦创。 首发:https://mp.weixin.qq.com/s/6MTkpWZCEbFWOcUn0Vexvw V0.1 版本我将分为上中下三篇进行书写和发布,欢迎分享和我微信进讨论群:Jiabcdefh。 计划: 会迭代好几个版本,看阅读量和点赞…...
【23真题】罕见211!数一配英二!
今天分享的是23年合肥工业大学833的信号与系统数字信号处理试题及解析。合工大833考数一英二,这样的搭配还是很少见的。 本套试卷难度分析:22年合肥工业大学833考研真题,我也发布过,若有需要,戳这里自取!平均分为80和…...
Linux 项目自动化构建工具:make/makefile
什么是 make make 是一个命令,他会在源文件的当前目录下寻找 makefile 或者 Makefile 文件执行这个文件中的代码。 makefile 文件的编写 我们先来见见猪跑,看看 make 怎么用的: 下面是 makefile 文件的内容: 这是 test.c 中的…...
android trace文件的抓取与查看方法
本地手机抓取trace 解压android trace文件的抓取与查看方法 找到config.pbtx文件,连接手机push进去 # push config.pbtx ,/data/local/tmp/为自定义push到的目录 adb push config.pbtx /data/local/tmp/ adb shell # 抓取trace, /data/loc…...
ffmpeg开发 环境配置
ffmpeg开发简图 1 下载ffmpeg开发包 https://ffmpeg.org/download.html 包含三个版本:Static、Shared以及Dev Static --- 包含3个应用程序:ffmpeg.exe , ffplay.exe , ffprobe.exe,体积都很大,相关的DLL已经被编译到exe里面去…...
C++STL——string类详解及其模拟实现
CSTL——string类 1. STL简介 STL全称standard template libaray,译为标准模板库 需要注意,STL不是C的标准库,而是C标准库的重要组成部分STL是一个包含众多数据结构和算法的软件框架 下面展示STL的六大组件: 本章,我…...
使用Three.js创建导航立方体
什么是导航立方体? 导航立方体是一个交互式的3D控件,它允许用户通过点击和拖动立方体的各个面来改变3D视图的方向。这是一种非常直观的方式,让用户能够轻松地在3D空间中导航。 创建导航立方体 下面是一个基本的步骤,说明如何使用Three.js创建一个导航立方体: // 创建场景…...
C++_核心编程_多态案例二-制作饮品
#include <iostream> #include <string> using namespace std;/*制作饮品的大致流程为:煮水 - 冲泡 - 倒入杯中 - 加入辅料 利用多态技术实现本案例,提供抽象制作饮品基类,提供子类制作咖啡和茶叶*//*基类*/ class AbstractDr…...
Flask RESTful 示例
目录 1. 环境准备2. 安装依赖3. 修改main.py4. 运行应用5. API使用示例获取所有任务获取单个任务创建新任务更新任务删除任务 中文乱码问题: 下面创建一个简单的Flask RESTful API示例。首先,我们需要创建环境,安装必要的依赖,然后…...
安宝特方案丨XRSOP人员作业标准化管理平台:AR智慧点检验收套件
在选煤厂、化工厂、钢铁厂等过程生产型企业,其生产设备的运行效率和非计划停机对工业制造效益有较大影响。 随着企业自动化和智能化建设的推进,需提前预防假检、错检、漏检,推动智慧生产运维系统数据的流动和现场赋能应用。同时,…...
【HTML-16】深入理解HTML中的块元素与行内元素
HTML元素根据其显示特性可以分为两大类:块元素(Block-level Elements)和行内元素(Inline Elements)。理解这两者的区别对于构建良好的网页布局至关重要。本文将全面解析这两种元素的特性、区别以及实际应用场景。 1. 块元素(Block-level Elements) 1.1 基本特性 …...
Ascend NPU上适配Step-Audio模型
1 概述 1.1 简述 Step-Audio 是业界首个集语音理解与生成控制一体化的产品级开源实时语音对话系统,支持多语言对话(如 中文,英文,日语),语音情感(如 开心,悲伤)&#x…...
成都鼎讯硬核科技!雷达目标与干扰模拟器,以卓越性能制胜电磁频谱战
在现代战争中,电磁频谱已成为继陆、海、空、天之后的 “第五维战场”,雷达作为电磁频谱领域的关键装备,其干扰与抗干扰能力的较量,直接影响着战争的胜负走向。由成都鼎讯科技匠心打造的雷达目标与干扰模拟器,凭借数字射…...
QT: `long long` 类型转换为 `QString` 2025.6.5
在 Qt 中,将 long long 类型转换为 QString 可以通过以下两种常用方法实现: 方法 1:使用 QString::number() 直接调用 QString 的静态方法 number(),将数值转换为字符串: long long value 1234567890123456789LL; …...
OpenLayers 分屏对比(地图联动)
注:当前使用的是 ol 5.3.0 版本,天地图使用的key请到天地图官网申请,并替换为自己的key 地图分屏对比在WebGIS开发中是很常见的功能,和卷帘图层不一样的是,分屏对比是在各个地图中添加相同或者不同的图层进行对比查看。…...
NXP S32K146 T-Box 携手 SD NAND(贴片式TF卡):驱动汽车智能革新的黄金组合
在汽车智能化的汹涌浪潮中,车辆不再仅仅是传统的交通工具,而是逐步演变为高度智能的移动终端。这一转变的核心支撑,来自于车内关键技术的深度融合与协同创新。车载远程信息处理盒(T-Box)方案:NXP S32K146 与…...
代码规范和架构【立芯理论一】(2025.06.08)
1、代码规范的目标 代码简洁精炼、美观,可持续性好高效率高复用,可移植性好高内聚,低耦合没有冗余规范性,代码有规可循,可以看出自己当时的思考过程特殊排版,特殊语法,特殊指令,必须…...
