当前位置: 首页 > news >正文

java 2(程序流程控制)【含例题详解】

java ——程序流程控制

✍作者:电子科大不知名程序员

🌲专栏:java学习指导

各位读者如果觉得博主写的不错,请诸位多多支持;如果有错误的地方,欢迎在评论区指出

目录

  • java ——程序流程控制
    • 分支结构
      • if-else
      • switch-case
      • scanner
    • 循环
      • for 循环
      • while 循环
      • do-while 循环
    • 嵌套循环
    • break和continue
    • break和continue

三种基本流程结构:顺序结构、分支结构、循环结构

分支结构

if-else

三种结构:

if(条件表达式){执行代码块;
}
//二选一
if(条件表达式){执行代码块1;
}
else{执行代码块2;
}
//多选一
if(条件表达式1){执行代码块1;
}else if(条件表达式2){执行代码块2;}
......else{执行代码块n;}

switch-case

1.格式

switch(表达式){
case 常量1:语句1;//break;
case 常量2:语句2;//break;
......
case 常量N:语句N;    break;
default:语句;//break;
}

//break的意思是不一定要用break

public class SwitchCaseTest {public static void main(String[] args) {int number=2;switch(number) {case 0:System.out.println("zero");case 1:System.out.println("one");case 2:System.out.println("two");case 3:System.out.println("three");default:System.out.println("other");}}
}

运行结果如下:

image-20220912233945991

【说明】:

1.根据switch表达式中的值,一次匹配各个case中的常量,一旦匹配成功,进入相应case结构中,调用其执行语句,当调用完执行语句后,则仍然继续向下执行其它case结构中的执行语句,直到遇到break关键字或者switch-case末尾结束为止;

2.要想像if-else那样的多选一:需要在每一个case后加break;

break:可以使用在switch-case结构中,表示一旦执行到此关键字,就跳出switch-case结构;

3.switch结构中的表达式,只能是如下的6种数据类型之一:byte、short、char、int、枚举类型、String类型

boolean isRight=ture;
switch(isRight){              //wrong......
}

4.case后放的是常量,不能作范围判断(相当于判断==)

5.break关键字在switch结构中是可选的(绝大多数情况要加)

6.default相当于if-else结构中的else中类型,当前面情况(case)都不满足时执行

​ default也是可选的,且位置是灵活的(用不到)

实例1:

import java.util.Scanner;
public class SwitchCase3 {//对于学生成绩大于60分的,输出“合格”。低于60分的,输出不合格public static void main(String[] args) {Scanner scan=new Scanner(System.in);int score_1=scan.nextInt();int score_2=score_1/10;switch(score_2) {case 1:case 2:case 3:case 4:case 5:System.out.println("Failed");break;case 6:case 7:case 8:case 9:case 10:System.out.println("pass");break;}}
}

优化:switch(score_1/60)——这样就分成了及格和不及格的两种情况了

实例2:

package my_first_java_code;import java.util.Scanner;
public class SwitchCase4 {public static void main(String [] args){//编写程序:从键盘上输入2022年的月份和日期,通过程序求得这是2022的第几天Scanner scan=new Scanner(System.in);System.out.println("Please enter a month:");int month=scan.nextInt();System.out.println("Please enter a day:");int day=scan.nextInt();//定义一个变量来保存总天数int sumDays=0;/*方法1:过于的冗余* switch(month) {case 1:sumDays=day;case 2:sumDays=31+day;case 3:...}*///方法2:我们不妨思考,因为我们到下个月的时候正好要将前面所有月的天数相加,因此不妨将前几个月的天数写在下面,那么没有break的情况下就会自动执行switch(month) {case 12:sumDays+=30;case 11:sumDays+=31;case 10:sumDays+=30;case 9:sumDays+=31;case 8:sumDays+=31;case 7:sumDays+=30;case 6:sumDays+=31;case 5:sumDays+=30;case 4:sumDays+=31;case 3:sumDays+=28;case 2:sumDays+=31;case 1:sumDays=day;}System.out.println("2022年的第"+month+"月第"+day+"日是第"+sumDays+"天");//注意用连接符连接}
}

通过实例2:我们再次强调,break是可选的马,根据实际要求来

实例3:不仅仅考虑2022年,我们加入对年的思考——需要判断是否是闰年

import java.util.Scanner;
public class SwitchCaseTest5 {public static void main(String[] args) {Scanner scan=new Scanner(System.in);System.out.println("Please enter a year:");int year=scan.nextInt();System.out.println("Please enter a month:");int month=scan.nextInt();System.out.println("Please enter a day:");int day=scan.nextInt();//定义一个变量来保存总天数int sumDays=0;switch(month) {case 12:sumDays+=30;case 11:sumDays+=31;case 10:sumDays+=30;case 9:sumDays+=31;case 8:sumDays+=31;case 7:sumDays+=30;case 6:sumDays+=31;case 5:sumDays+=30;case 4:sumDays+=31;case 3://根据是否是闰年来决定//sumDays+=28;if(year%4==0&&year%100!=0||year/400==0) {sumDays+=29;   //是闰年}else {sumDays+=28;   //不是闰年}case 2:sumDays+=31;case 1:sumDays=day;}System.out.println(year+"年的第"+month+"月第"+day+"日是第"+sumDays+"天");}
}

scanner

如何从键盘获取不同类型的变量:需要使用scanner类

具体实现步骤:

1.导包:import java.util.Scanner;

2.Scanner的实例化:Scanner scan=new Scanner(System.in);

3.调用Scanner类的相关方法:next()/nextXxx(),来获取指定类型的变量

对于String类,字符串型采用next();其它的采用/nextXxx()(注意首字母大写)

import java.util.Scanner;
public class ScannerTest {public static void main(String[] args) {Scanner scan=new Scanner(System.in);int num=scan.nextInt();    //int型System.out.println(num);}
}
import java.util.Scanner;
public class ScannnerTest02 {public static void main(String[] args) {Scanner scan=new Scanner(System.in);System.out.println("Please enter your name");String name=scan.next();System.out.println(name);System.out.println("Please enter your age");int age=scan.nextInt();System.out.println(age);System.out.println("Please enter your weight");double weight=scan.nextDouble();System.out.println(weight);System.out.println("Whether you join us (true/false)");boolean isjoin=scan.nextBoolean();System.out.println(isjoin);}
}

注意:我们需要根据相应的方法,来输入指定类型的值。如果输入的数据类型与要求的类型不匹配时,会报异常:InputMisMatchExce导致程序终止

循环

循环的四个组成部分:

1.初始化部分------>2.循环条件部分(boolean类型)------->3.循环体部分------>4.迭代部分

for 循环

for(1初始化部分;2循环条件部分;4迭代部分){3循环体部分;
}

实例:输入两个数正整数m和n,求其最大公约数和最小公倍数

最大公约数:首先要确定范围:1-两数间的较小数;若要满足最大,那么从两数间的较小数开始循环,找到第一个满足条件的数即可(然后退出循环:break)

最小公倍数:范围:两数中的较大数-两数的乘积;后续同理

package my_first_java_code;
import java.util.Scanner;
public class ForTest {public static void main(String[] args) {Scanner scan=new Scanner(System.in);System.out.println("请输入第一个正整数");int first_num=scan.nextInt();System.out.println("请输入第二个正整数");int second_num=scan.nextInt();//求最大公约数//先求出两数的较小数——三目运算符int min=(first_num<second_num)?first_num:second_num;for(int i=min;i>=1;i--) {if(first_num%i==0&&second_num%i==0) {System.out.println("最大公约数为"+i);break;}}int max=(first_num>second_num)?first_num:second_num;for(int j=max;j<first_num*second_num;j++) {if(j%first_num==0&&j%second_num==0) {System.out.println("最小公倍数为"+j);break;}}}
}

while 循环

1初始化条件
while(2循环条件){3循环体;4迭代条件;
}

do-while 循环

1初始化条件
do{3循环体;4迭代条件;
}while(2循环条件)

说明:

1.do-while循环至少会执行一次循环体

2.当循环会执行多次时,do-while循环和while循环没有区别

实例:从键盘读入个数不确定的整数,并判断读入数的个数,输入0时为结束条件

import java.util.Scanner;
public class CirculateEG {public static void main(String[] args) {Scanner scan=new Scanner(System.in);int count=0;while(true) {int import_num=scan.nextInt();if(import_num!=0) {count++;System.out.println("输入的个数为:"+count);}elsebreak;}}
}

对于该类无法确定循环次数的问题:while(true)/for( ; ; ),然后再用break来控制

【总结】:结束循环的方式:循环条件返回false;循环体中,执行break

嵌套循环

外层控制行数;内层控制列数

常见模型:

/*
*
**
***
****
*****
*/
规律:i=j(=)
for(int i=1;i<=5;i++){for(int j=1;j<=i;j++){System.out.print("*");}System.out.println();       //换行
}
/*
*****
****
***
**
*
*/
规律:i+j=5(=)
for(int i=1;i<=5;i++){for(int j=1;j<=5-i;j++){System.out.print("*");}System.out.println();       //换行
}

实例1:九九乘法表

public class Nine_nine_multiplication_table {public static void main(String[] args){for(int i=1;i<=9;i++) {for(int j=1;j<=i;j++) {System.out.print(i+"*"+j+"="+i*j+" ");}System.out.println();}}
}

实例2:输出质数

1:

public class Output_prime_numbers {public static void main(String[] args){for(int i=2;i<=100;i++) {boolean isFlag=true;for(int j=2;j<i;j++) {      //判断i是否是质数if(i%j==0) {isFlag=false;}}if(isFlag==true) {System.out.println(i);}}}
}

这里使用到一个标志:是否除尽;需要特别注意的是:每次在判断完后需要重置isflag的值

2.优化

判断质数时若已经被整除了,那么就不用再循环下去了:break(对非质数有效)

为了判断优化是否有效,我们通过记录运行时间来直观的看是否优化(单位:毫秒)

public class Output_prime_number_optimized_V1 {public static void main(String[] args){//获取当前时间距离1970-01-01 00:00:00的时间差long start_time=System.currentTimeMillis();for(int i=2;i<=100000;i++) {boolean isFlag=true;for(int j=2;j<i;j++) {      //判断i是否是质数if(i%j==0) {isFlag=false;break;}}if(isFlag==true) {System.out.println(i);}}//获取当前时间距离1970-01-01 00:00:00的时间差long end_time=System.currentTimeMillis();System.out.println("该程序运行时间为:"+(end_time-start_time));}
}

优化前程序运行时间与优化后程序运行时间如下:

在这里插入图片描述
很明显,时间相差10倍!

这里使用到了:

long start_time=System.currentTimeMillis();

System.currentTimeMillis();的返回值为整型,

3.再优化

方法:数学上有个规律,对于一个小于n的整数x,若n不能整除x,则n必定不能整数n/x,那么带来一个明显的优化就是循环控制语句从2到根号n即可。

修改为:

for(int j=2;j<Math.sqrt(i);j++)

这里对i求根号用到了数学方法:

Math.sqrt();    //括号内放开根数

再次优化后程序运行时间如下:

image-20220913215434083

break和continue

1.break:switch-case/循环结构中 作用:结束当前循环

2.continue:循环结构中 作用:结束当次循环

相同点:在break和continue之后是不能声明执行语句

3.对于嵌套循环内:break默认跳出包裹此关键字最近的一层循环

​ ------>若要结束某一特定的for循环:使用标签(continue同理)

label:for( ; ;){for( ; ;){break label;   //结束指定标识的一层循环结构}
}

实例:输出质数的另一种写法

label:for(int i=2;i<=100;i++) {for(int j=2;j<=Math.sqrt(i);j++) {      //判断i是否是质数if(i%j==0) {                       //如果出现了整除continue label;}}//能执行到此步骤的,都是质数System.out.println(i);
}

7591011354)]

break和continue

1.break:switch-case/循环结构中 作用:结束当前循环

2.continue:循环结构中 作用:结束当次循环

相同点:在break和continue之后是不能声明执行语句

3.对于嵌套循环内:break默认跳出包裹此关键字最近的一层循环

​ ------>若要结束某一特定的for循环:使用标签(continue同理)

label:for( ; ;){for( ; ;){break label;   //结束指定标识的一层循环结构}
}

实例:输出质数的另一种写法

label:for(int i=2;i<=100;i++) {for(int j=2;j<=Math.sqrt(i);j++) {      //判断i是否是质数if(i%j==0) {                       //如果出现了整除continue label;}}//能执行到此步骤的,都是质数System.out.println(i);
}

相关文章:

java 2(程序流程控制)【含例题详解】

java ——程序流程控制 ✍作者&#xff1a;电子科大不知名程序员 &#x1f332;专栏&#xff1a;java学习指导 各位读者如果觉得博主写的不错&#xff0c;请诸位多多支持&#xff1b;如果有错误的地方&#xff0c;欢迎在评论区指出 目录java ——程序流程控制分支结构if-elsesw…...

基于Conda完成创建多版本python环境

文章目录基于Conda完成创建多版本python环境基于Conda完成创建多版本python环境 通过cmd打开conda环境 d:\ProgramData\Anaconda3\Scripts\activate创建python3.7的环境 conda create -n py3.7 python3.7产生错误 Collecting package metadata (repodata.json): failed Unav…...

35岁的测试被裁,公司地位还不如00后...

国内的互联网行业发展较快&#xff0c;所以造成了技术研发类员工工作强度比较大&#xff0c;同时技术的快速更新又需要员工不断的学习新的技术。因此淘汰率也比较高&#xff0c;超过35岁的基层研发类员工&#xff0c;往往因为家庭原因、身体原因&#xff0c;比较难以跟得上工作…...

vue H5跳转小程序报错:config:fail,Error: 系统错误,错误码:63002,invalid signature

微信开发者工具下载地址与更新日志 错误码&#xff1a;63002,invalid signature 无效的签名 附录5 微信网页开发 /JS-SDK说明文档 微信 JS 接口签名校验工具 全局返回码说明 ​ 排查步骤 确认签名算法正确&#xff0c;可用 http://mp.weixin.qq.com/debug/cgi-bin/sand…...

来面试阿里测开工程师,HR问我未来3-5年规划,我给HR画个大饼。

在面试的过程中是不是经常被面试官问未来几年的职业规划?你会答吗&#xff1f;是不是经常脑袋里一片空白&#xff0c;未来规划&#xff1f;我只是想赚更多的钱啊&#xff0c;哈哈哈&#xff0c;今天我来教大家&#xff0c;如何给面试官画一个大饼&#xff0c;让他吃的不亦乐乎…...

【2373. 矩阵中的局部最大值】

来源&#xff1a;力扣&#xff08;LeetCode&#xff09; 描述&#xff1a; 给你一个大小为 n x n 的整数矩阵 grid 。 生成一个大小为 (n - 2) x (n - 2) 的整数矩阵 maxLocal &#xff0c;并满足&#xff1a; maxLocal[i][j] 等于 grid 中以 i 1 行和 j 1 列为中心的 3 …...

Read book Netty in action(Chapter VII)--ChannelHandler和ChannelPipeline

序言 我们曾经学过了ByteBuf – netty的数据容器&#xff0c;还有ChannelHandler和ChannelPipeline&#xff0c;这一把将他们组合起来&#xff0c;这些组件的交互正是Netty的灵魂所在&#xff01; ChannelHanlder家族 在详细地学习ChannelHanlder之前&#xff0c;我们将在Ne…...

react的严格模式 和 解决react useEffect执行两次

useEffect执行两次 这个问题&#xff0c;主要是刚接触react的时候发的问题&#xff0c;当时也没总结。现在回过头来再总结一次&#xff01;&#xff01;&#xff01; 文章目录useEffect执行两次前言一、为什么useEffect执行两次1.React的严格模式&#xff08;模版创建项目&…...

C++中的STL

一、概念 STL&#xff0c;英文全称 standard template library&#xff0c;中文可译为标准模板库或者泛型库&#xff0c;其包含有大量的模板类和模板函数&#xff0c;是 C 提供的一个基础模板的集合&#xff0c;用于完成诸如输入/输出、数学计算等功能。 STL 最初由惠普实验室…...

【沐风老师】3dmax一键窗户生成器插件使用方法详解

3dmax一键窗户生成器插件教程 3dMax一键窗户生成器是一个在3dMax中自动创建3D窗户模型的脚本。它有28种风格的窗户样式&#xff0c;可以在Archviz项目中灵活应用&#xff0c;同时为3D艺术家节省大量时间。 【适用版本】 适用3dMax 2018.2及更高版本 【安装方法】 1.解压缩包&…...

【图像处理】数字图像处理基础(分辨率,像素,显示...)

Table of Contents1.数字图像处理基础1.1 图像表示1.1.1 图像成像模型1.1.2 数字图像的表示a.图像采样b.图像灰度的量化c.算比特数1.2 分辨率1.2.1 空间分辨率1.2.2 灰度分辨率1.3 像素间的关系1.3.1 像素邻域a.4邻域b.4对角邻域c.8邻域1.3.2 像素邻接1.3.3 像素连通1.3.4 像素…...

UE实现相机飞行效果CesiumForUnreal之DynamicPawn飞行原理浅析

文章目录 1.实现目标2.实现过程2.1 FlyTo实现原理与代码2.2 DynamicPawn飞行原理3.参考资料1.实现目标 基于CesiumForUnreal的Dynamic Pawn实现飞行效果GIF动图: 2.实现过程 实现原理较为简单,基于CesiumForUnreal插件中DynamicPawn中的Camera实现相关功能。其中FlyTo直接通…...

AIGC被ChatGPT带火!底层基础算力有望爆发式增长

ChatGPT火爆全球的背后&#xff0c;可以窥见伴随人工智能技术的发展&#xff0c;数字内容的生产方式向着更加高效迈进。ChatGPT属于AIGC的具体应用&#xff0c;而AIGC是技术驱动的数字内容新生产方式。AIGC类产品未来有望成为5G时代新的流量入口&#xff0c;率先受益的有望是AI…...

【链表OJ题(一)】移除链表元素

​ ​&#x1f4dd;个人主页&#xff1a;Sherry的成长之路 &#x1f3e0;学习社区&#xff1a;Sherry的成长之路&#xff08;个人社区&#xff09; &#x1f4d6;专栏链接&#xff1a;数据结构 &#x1f3af;长路漫漫浩浩&#xff0c;万事皆有期待 文章目录链表OJ题(一)1. 移除…...

【解锁技能】学会Python条件语句的终极指南!

文章目录前言一. python条件语句的介绍1.1 什么是条件语句1.2 条件语句的语法1.3 关于内置函数bool()二. 分支语句之单分支三. 多分支语句3.1 二分支语句3.2 多分支语句3.3 嵌套循环总结前言 &#x1f3e0;个人主页&#xff1a;欢迎访问 沐风晓月的博客 &#x1f9d1;个人简介&…...

如何通过rem实现移动端的适配?

一、rem、em、vw\vh的区别&#xff1a; rem&#xff1a;参照HTML根元素的font-size em&#xff1a;参照自己的font-size vw/vh&#xff1a;将视口宽高平分100等份&#xff0c;数值就是所占比例 <!DOCTYPE html> <html lang"en"><head><meta…...

【论文阅读】-姿态识别

记录论文阅读&#xff0c;希望能了解我方向的邻域前沿吧 粗读 第一篇 ATTEND TO WHO YOU ARE: SUPERVISING SELF-ATTENTION FOR KEYPOINT DETECTION AND INSTANCE-AWARE ASSOCIATION 翻译&#xff1a;https://editor.csdn.net/md?not_checkout1&spm1001.2014.3001.5352…...

3.1 模拟栈+表达式求值

模拟栈 题目链接 栈的数组模拟非常简单&#xff0c;不详细描述 设置一个指针指向栈顶第一个元素即可 STL中stack实现已经更新在STL_Stack #include<iostream> #include<string>using namespace std;const int N1e51; int m; string s; int stack[N]; int p;//指针…...

【Python语言基础】——Python 创建表

Python语言基础——Python 创建表 文章目录 Python语言基础——Python 创建表一、Python 创建表一、Python 创建表 创建表 如需在 MySQL 中创建表,请使用 “CREATE TABLE” 语句。 请确保在创建连接时定义数据库的名称。 实例 创建表 “customers”: import mysql.connector…...

外贸建站,为什么别人的询盘更多更精准?

大多企业进行外贸建站的目的就是想要获得更多的精准询盘&#xff0c;但是具体该如何做&#xff0c;大多企业都没有方向&#xff0c;要么就是在网上看各种不系统的文章学着操作&#xff0c;要么就找个建站公司做好网站就不管了&#xff0c;而最终结果都不甚理想。那么怎样才能让…...

【kafka】Golang实现分布式Masscan任务调度系统

要求&#xff1a; 输出两个程序&#xff0c;一个命令行程序&#xff08;命令行参数用flag&#xff09;和一个服务端程序。 命令行程序支持通过命令行参数配置下发IP或IP段、端口、扫描带宽&#xff0c;然后将消息推送到kafka里面。 服务端程序&#xff1a; 从kafka消费者接收…...

Xshell远程连接Kali(默认 | 私钥)Note版

前言:xshell远程连接&#xff0c;私钥连接和常规默认连接 任务一 开启ssh服务 service ssh status //查看ssh服务状态 service ssh start //开启ssh服务 update-rc.d ssh enable //开启自启动ssh服务 任务二 修改配置文件 vi /etc/ssh/ssh_config //第一…...

java 实现excel文件转pdf | 无水印 | 无限制

文章目录 目录 文章目录 前言 1.项目远程仓库配置 2.pom文件引入相关依赖 3.代码破解 二、Excel转PDF 1.代码实现 2.Aspose.License.xml 授权文件 总结 前言 java处理excel转pdf一直没找到什么好用的免费jar包工具,自己手写的难度,恐怕高级程序员花费一年的事件,也…...

CMake基础:构建流程详解

目录 1.CMake构建过程的基本流程 2.CMake构建的具体步骤 2.1.创建构建目录 2.2.使用 CMake 生成构建文件 2.3.编译和构建 2.4.清理构建文件 2.5.重新配置和构建 3.跨平台构建示例 4.工具链与交叉编译 5.CMake构建后的项目结构解析 5.1.CMake构建后的目录结构 5.2.构…...

系统设计 --- MongoDB亿级数据查询优化策略

系统设计 --- MongoDB亿级数据查询分表策略 背景Solution --- 分表 背景 使用audit log实现Audi Trail功能 Audit Trail范围: 六个月数据量: 每秒5-7条audi log&#xff0c;共计7千万 – 1亿条数据需要实现全文检索按照时间倒序因为license问题&#xff0c;不能使用ELK只能使用…...

【CSS position 属性】static、relative、fixed、absolute 、sticky详细介绍,多层嵌套定位示例

文章目录 ★ position 的五种类型及基本用法 ★ 一、position 属性概述 二、position 的五种类型详解(初学者版) 1. static(默认值) 2. relative(相对定位) 3. absolute(绝对定位) 4. fixed(固定定位) 5. sticky(粘性定位) 三、定位元素的层级关系(z-i…...

【C++从零实现Json-Rpc框架】第六弹 —— 服务端模块划分

一、项目背景回顾 前五弹完成了Json-Rpc协议解析、请求处理、客户端调用等基础模块搭建。 本弹重点聚焦于服务端的模块划分与架构设计&#xff0c;提升代码结构的可维护性与扩展性。 二、服务端模块设计目标 高内聚低耦合&#xff1a;各模块职责清晰&#xff0c;便于独立开发…...

在WSL2的Ubuntu镜像中安装Docker

Docker官网链接: https://docs.docker.com/engine/install/ubuntu/ 1、运行以下命令卸载所有冲突的软件包&#xff1a; for pkg in docker.io docker-doc docker-compose docker-compose-v2 podman-docker containerd runc; do sudo apt-get remove $pkg; done2、设置Docker…...

第 86 场周赛:矩阵中的幻方、钥匙和房间、将数组拆分成斐波那契序列、猜猜这个单词

Q1、[中等] 矩阵中的幻方 1、题目描述 3 x 3 的幻方是一个填充有 从 1 到 9 的不同数字的 3 x 3 矩阵&#xff0c;其中每行&#xff0c;每列以及两条对角线上的各数之和都相等。 给定一个由整数组成的row x col 的 grid&#xff0c;其中有多少个 3 3 的 “幻方” 子矩阵&am…...

C++使用 new 来创建动态数组

问题&#xff1a; 不能使用变量定义数组大小 原因&#xff1a; 这是因为数组在内存中是连续存储的&#xff0c;编译器需要在编译阶段就确定数组的大小&#xff0c;以便正确地分配内存空间。如果允许使用变量来定义数组的大小&#xff0c;那么编译器就无法在编译时确定数组的大…...