当前位置: 首页 > 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;而最终结果都不甚理想。那么怎样才能让…...

Chapter03-Authentication vulnerabilities

文章目录 1. 身份验证简介1.1 What is authentication1.2 difference between authentication and authorization1.3 身份验证机制失效的原因1.4 身份验证机制失效的影响 2. 基于登录功能的漏洞2.1 密码爆破2.2 用户名枚举2.3 有缺陷的暴力破解防护2.3.1 如果用户登录尝试失败次…...

Leetcode 3576. Transform Array to All Equal Elements

Leetcode 3576. Transform Array to All Equal Elements 1. 解题思路2. 代码实现 题目链接&#xff1a;3576. Transform Array to All Equal Elements 1. 解题思路 这一题思路上就是分别考察一下是否能将其转化为全1或者全-1数组即可。 至于每一种情况是否可以达到&#xf…...

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.构…...

【解密LSTM、GRU如何解决传统RNN梯度消失问题】

解密LSTM与GRU&#xff1a;如何让RNN变得更聪明&#xff1f; 在深度学习的世界里&#xff0c;循环神经网络&#xff08;RNN&#xff09;以其卓越的序列数据处理能力广泛应用于自然语言处理、时间序列预测等领域。然而&#xff0c;传统RNN存在的一个严重问题——梯度消失&#…...

页面渲染流程与性能优化

页面渲染流程与性能优化详解&#xff08;完整版&#xff09; 一、现代浏览器渲染流程&#xff08;详细说明&#xff09; 1. 构建DOM树 浏览器接收到HTML文档后&#xff0c;会逐步解析并构建DOM&#xff08;Document Object Model&#xff09;树。具体过程如下&#xff1a; (…...

QT3D学习笔记——圆台、圆锥

类名作用Qt3DWindow3D渲染窗口容器QEntity场景中的实体&#xff08;对象或容器&#xff09;QCamera控制观察视角QPointLight点光源QConeMesh圆锥几何网格QTransform控制实体的位置/旋转/缩放QPhongMaterialPhong光照材质&#xff08;定义颜色、反光等&#xff09;QFirstPersonC…...

GO协程(Goroutine)问题总结

在使用Go语言来编写代码时&#xff0c;遇到的一些问题总结一下 [参考文档]&#xff1a;https://www.topgoer.com/%E5%B9%B6%E5%8F%91%E7%BC%96%E7%A8%8B/goroutine.html 1. main()函数默认的Goroutine 场景再现&#xff1a; 今天在看到这个教程的时候&#xff0c;在自己的电…...

mac:大模型系列测试

0 MAC 前几天经过学生优惠以及国补17K入手了mac studio,然后这两天亲自测试其模型行运用能力如何&#xff0c;是否支持微调、推理速度等能力。下面进入正文。 1 mac 与 unsloth 按照下面的进行安装以及测试&#xff0c;是可以跑通文章里面的代码。训练速度也是很快的。 注意…...

ZYNQ学习记录FPGA(一)ZYNQ简介

一、知识准备 1.一些术语,缩写和概念&#xff1a; 1&#xff09;ZYNQ全称&#xff1a;ZYNQ7000 All Pgrammable SoC 2&#xff09;SoC:system on chips(片上系统)&#xff0c;对比集成电路的SoB&#xff08;system on board&#xff09; 3&#xff09;ARM&#xff1a;处理器…...

算法打卡第18天

从中序与后序遍历序列构造二叉树 (力扣106题) 给定两个整数数组 inorder 和 postorder &#xff0c;其中 inorder 是二叉树的中序遍历&#xff0c; postorder 是同一棵树的后序遍历&#xff0c;请你构造并返回这颗 二叉树 。 示例 1: 输入&#xff1a;inorder [9,3,15,20,7…...