【Java】循环语句练习

news2024/11/30 3:36:26

文章目录

  • 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^3
    public 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!!!✊

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1256039.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

GWAS:plink进行meta分析

之前教程提到过Metal是可以做Meta分析&#xff0c;除了Metal&#xff0c;PLINK也可以进行Meta分析。 命令如下所示&#xff1a; plink --meta-analysis gwas1.plink gwas2.plink gwas3.plink logscale qt --meta-analysis-snp-field SNP --meta-analysis-chr-field CHR --me…

C++初识类和对象

前言 上一期我们介绍了一些C入门的基础知识&#xff0c;本期我们来介绍面向对象。初步认识一下面向对象和面向过程、类、以及封装&#xff01; 本期内容介绍 面向过程和面向对象 类的引入 类的定义 类的访问限定符和封装 类的作用域 类的实例化 类对象模型 this指针 一、面向…

从零开始学习管道:管道程序的优化和文件描述符继承问题

&#x1f4df;作者主页&#xff1a;慢热的陕西人 &#x1f334;专栏链接&#xff1a;Linux &#x1f4e3;欢迎各位大佬&#x1f44d;点赞&#x1f525;关注&#x1f693;收藏&#xff0c;&#x1f349;留言 本博客主要内容管道后续的完善&#xff0c;以及解决管道继承多个文件描…

Unity - Graphic解析

Gpahic 的作用 Graphic 是 Unity最基础的图形基类。主要负责UGUI的显示部分。 由上图可以看你出我们经常使用的Image&#xff0c;Text&#xff0c;都是继承自Graphic。 Graphic的渲染流程 在Graphic的源码中有以下属性 [NonSerialized] private CanvasRenderer m_CanvasRend…

【Python游戏开发】使用Python编写拼图益智游戏教程

使用Python编写拼图益智游戏 大家一般都玩过拼图益智游戏&#xff0c;或者类似的游戏。今天&#xff0c;就给大家使用pygame库在Python中构建一个拼图益智小游戏。这个拼图小游戏是构建一个围绕着将1-15个数字排列在16个方块的网格中的游戏。 现在&#xff0c;让我们从今天的惊…

【数据中台】开源项目(2)-Dbus数据总线

1 背景 企业中大量业务数据保存在各个业务系统数据库中&#xff0c;过去通常的同步数据的方法有很多种&#xff0c;比如&#xff1a; 各个数据使用方在业务低峰期各种抽取所需数据&#xff08;缺点是存在重复抽取而且数据不一致&#xff09; 由统一的数仓平台通过sqoop到各个…

那些年,关于CKACKS认证的那些事儿?

前言 遥想2020年的年初&#xff0c;疫情封城封村之际&#xff0c;工作之余在B站将尚硅谷的linux中的k8s视频完整系统的学习了一遍&#xff0c;自此像是打通了任督二脉一般&#xff0c;开启了对k8s的探索之旅&#xff0c;一路也是磕磕绊绊的在工作中使用k8s。 终于在23年的6月仲…

Rust在Web开发中的应用

欢迎关注我的公众号lincyang新自媒体&#xff0c;回复关键字【程序员经典书单】&#xff0c;领取程序员的100本经典书单 大家好&#xff01;我是lincyang。 今天我们将一起深入探索Rust在Web开发领域的应用。尽管Rust最初设计用于系统编程&#xff0c;但其性能、安全性和现代并…

CANdelaStudio 使用教程5 编辑DID

文章目录 在哪编辑DID的分类编辑快照数据添加 DID 在哪编辑 DID的分类 编辑快照数据 添加 DID

带你用uniapp从零开发一个仿小米商场_9. 轮播图组件封装及使用

导航栏有了,接下来就是轮播图了,轮播图如下, 因为uniapp 官方自己有轮播图,所以这里就不自己写了,直接使用uniapp的轮播图二次开发就好 uniapp的轮播图组件叫swiper ,感兴趣的朋友可以点击链接,直接去看官方文档,也可以看我这里实操 用hbuilderX编译uniapp的代码有一个好处…

redis实现消息延迟队列

业务场景 在很多软件系统功能中都会出现定时任务的业务场景,比如提前点单,比如定时发布动态,文章等而出现这样的的定时的任务为延迟队任务 代码模块 任务的持久化一般都需要建立一个任务表和任务日志表,避免宕机导致任务失效,先新建立一个数据库,创建基本的任务表和任务日志表…

uniapp+vue基于Android的校园二手跳蚤市场的设计与实现 微信小程序

实现功能&#xff1a; 用户管理&#xff1a;登陆、注册、注销、修改密码、上传头像、修改资料 发布与检索&#xff1a;发布商品、模糊搜索、人气排序、价格排序、时间排序、推送商品&#xff08;协同过滤算法实现个性化推荐&#xff09;&#xff0c;最新发布、分类检索 核心交易…

Less 嵌套规则

文章目录 前言描述style.less输出后言 前言 hello world欢迎来到前端的新世界 &#x1f61c;当前文章系列专栏&#xff1a;Sass和Less &#x1f431;‍&#x1f453;博主在前端领域还有很多知识和技术需要掌握&#xff0c;正在不断努力填补技术短板。(如果出现错误&#xff0c;…

【数据中台】开源项目(1)-LarkMidTable

LarkMidTable 是一站式开源的数据中台&#xff0c;实现中台的 基础建设&#xff0c;数据治理&#xff0c;数据开发&#xff0c;监控告警&#xff0c;数据服务&#xff0c;数据的可视化&#xff0c;实现高效赋能数据前台并提供数据服务的产品。 系统演示地址 &#xff1a; www.l…

案例027:基于微信小程序的校园二手平台的设计与实现

文末获取源码 开发语言&#xff1a;Java 框架&#xff1a;SSM JDK版本&#xff1a;JDK1.8 数据库&#xff1a;mysql 5.7 开发软件&#xff1a;eclipse/myeclipse/idea Maven包&#xff1a;Maven3.5.4 小程序框架&#xff1a;uniapp 小程序开发软件&#xff1a;HBuilder X 小程序…

【漏洞复现】熊海cms 存在sql注入 附poc

漏洞描述 熊海CMS 是由熊海开发的一款可广泛应用于个人博客,个人网站,企业网站的一套网站综合管理系统。 其采用前后端整合设计思路,php,Apache,mysql,前端使用Bootstrap和少许jquery前端框架开发; 网站样式设计简洁大方,整体功能点并不多,但功能正好够用;拥有一个…

AI辅助工具

任务拆解工具 Magic ToDo - GoblinTools 可用的AI搜索和对话工具&#xff1a;chatgpt 梦畅AI

打开CMD的六种方法,CMD快捷键,CMD命令大全及详解

目录 前言1. winR快捷键2、通过文本文档创建&#xff1b;3、通过C盘中的cmd.exe文件打开&#xff1b;4、创建快捷方式&#xff1b;5、通过PowerShell打开&#xff1b;6、通过文件夹导航栏打开&#xff1b; 前言 自己的电脑win键失灵了&#xff0c;想通过winR来调出cmd&#xff…

【聚类 | K-means】原理及推导流程(附模板代码,库手撕实现)

&#x1f935;‍♂️ 个人主页: AI_magician &#x1f4e1;主页地址&#xff1a; 作者简介&#xff1a;CSDN内容合伙人&#xff0c;全栈领域优质创作者。 &#x1f468;‍&#x1f4bb;景愿&#xff1a;旨在于能和更多的热爱计算机的伙伴一起成长&#xff01;&#xff01;&…

代码随想录算法训练营第四十八天|121. 买卖股票的最佳时机、122. 买卖股票的最佳时机 II

LeetCode 121. 买卖股票的最佳时机 题目链接&#xff1a;121. 买卖股票的最佳时机 - 力扣&#xff08;LeetCode&#xff09; 直觉告诉我要贪心算法&#xff0c;章节告诉我得用DP来做&#xff0c;行&#xff0c;都做一下&#xff01; 贪心&#xff1a;只能买一次&#xff0c;所…