java从入门到起飞(八)——循环和递归

文章目录

  • Java循环
    • 1. 什么是循环?
      • 1.1 为什么需要循环?
      • 1.2 循环的分类
    • 2. Java中的循环结构
      • 2.1 for循环
      • 2.2 while循环
      • 2.3 do-while循环
    • 3. 循环控制语句
      • 3.1 break语句
      • 3.2 continue语句
    • 4. 总结
  • Java递归
    • 1. 什么是递归
    • 2. 递归的原理
    • 3. 递归的实现
    • 4. 递归的应用
    • 5. 总结

Java循环

1. 什么是循环?

循环是一种重复执行特定代码块的结构。在编程中,我们经常需要重复执行某些任务,这时循环就派上了用场。

1.1 为什么需要循环?

循环使得程序可以自动化地执行重复的任务,而不需要手动重复编写相同的代码。它能够提高代码的可读性、简化程序的逻辑,并且方便对大量数据进行处理。

1.2 循环的分类

常见的循环类型包括:

  • 前测试循环:在执行循环体之前对循环条件进行判断,例如C语言中的for循环。
  • 后测试循环:在执行循环体之后对循环条件进行判断,例如Java中的while循环和do-while循环。
  • 无限循环:条件始终为真,例如在服务器程序中等待客户端连接的情况。

2. Java中的循环结构

在Java中,有三种主要的循环结构:for循环、while循环和do-while循环。它们分别适用于不同的应用场景。

2.1 for循环

for循环是一种前测试循环结构,它通常用于已知循环次数的情况。for循环由三部分组成:初始化、循环条件和循环迭代。

for (初始化; 循环条件; 循环迭代) {// 执行的代码块
}

例如,我们可以通过for循环输出数字1到10:

for (int i = 1; i <= 10; i++) {System.out.println(i);
}

2.2 while循环

while循环是一种前测试循环结构,它适用于未知循环次数但满足条件的情况。在执行循环体之前,先判断循环条件是否为真,如果为真则执行循环体。

while (循环条件) {// 执行的代码块
}

例如,我们可以通过while循环输出数字1到10:

int i = 1;
while (i <= 10) {System.out.println(i);i++;
}

2.3 do-while循环

do-while循环是一种后测试循环结构,它在执行循环体之后才判断循环条件。即使循环条件不满足,至少会执行一次循环体。

do {// 执行的代码块
} while (循环条件);

例如,我们可以通过do-while循环输出数字1到10:

int i = 1;
do {System.out.println(i);i++;
} while (i <= 10);

3. 循环控制语句

在循环中,还有一些特殊的语句用于控制循环的执行流程。

3.1 break语句

break语句用于提前结束循环,即使循环条件尚未满足。它可以用于任何循环结构(for循环、while循环和do-while循环)。

for (int i = 1; i <= 10; i++) {if (i == 5) {break;}System.out.println(i);
}

上面的示例中,当i等于5时,break语句会立即终止循环。

3.2 continue语句

continue语句用于跳过当前循环的剩余代码,继续下一次循环的执行。它也可以用于任何循环结构。

for (int i = 1; i <= 10; i++) {if (i % 2 == 0) {continue;}System.out.println(i);
}

上面的示例中,当i是偶数时,continue语句会跳过输出语句,直接进行下一次循环。

4. 总结

Java提供了for循环、while循环和do-while循环这三种主要的循环结构,用于重复执行特定的代码块。通过合理使用循环结构和循环控制语句,可以轻松处理重复性任务和大量数据的处理。

在使用循环时,需要注意循环条件的设置和循环体内的代码逻辑,以避免出现无限循环或错误的运算结果。同时,要根据具体的需求选择合适的循环结构,提高代码的可读性和可维护性。

希望本文对你理解和应用Java循环提供了一些帮助。​

Java递归

1. 什么是递归

递归是一种在函数内部调用自身的编程技巧。在Java中,递归是一种常见的算法和编程方法,用于解决需要重复执行相同操作的问题。

2. 递归的原理

递归的原理可以简单描述为以下几个步骤:

  1. 定义基本情况:确定递归终止的条件,即递归函数不再调用自身的情况。
  2. 定义递归规则:将问题划分为更小的子问题,并通过调用自身来解决子问题。
  3. 调用递归函数:在函数内部调用自身,将问题规模不断缩小,直到达到基本情况。
  4. 返回结果:将子问题的结果合并,得到最终的解。

3. 递归的实现

在Java中,实现递归通常需要定义一个递归函数。递归函数需要满足以下几个条件:

  • 基本情况:递归函数必须有一个或多个基本情况,当满足基本情况时,递归函数不再调用自身,直接返回结果。
  • 递归调用:递归函数内部需要调用自身,将问题划分为更小的子问题。
  • 问题规模减小:每次递归调用时,问题规模都应该比上一次调用时小,以确保递归能够终止。
    下面是一个简单的例子,用于计算一个正整数的阶乘:
public class RecursionExample {public static int factorial(int n) {// 基本情况:n为0或1时,直接返回1if (n == 0 || n == 1) {return 1;}// 递归调用:将问题规模缩小,计算n-1的阶乘return n * factorial(n - 1);}public static void main(String[] args) {int result = factorial(5);System.out.println("5的阶乘为:" + result);}
}

4. 递归的应用

递归在实际开发中有许多应用场景,例如:

  • 文件和目录的遍历:通过递归遍历文件夹和子文件夹,实现文件的查找、复制等操作。
  • 树的遍历:通过递归遍历二叉树或多叉树,实现查找、插入、删除等操作。
  • 数组和列表的操作:通过递归实现数组和列表的排序、搜索、合并等操作。

需要注意的是,递归可能会导致性能问题和堆栈溢出的风险。在使用递归时,需要合理设计递归终止条件,避免出现无限递归的情况。

5. 总结

递归是一种在函数内部调用自身的编程技巧,用于解决需要重复执行相同操作的问题。在Java中,递归通常通过定义递归函数来实现。递归函数需要满足基本情况、递归调用和问题规模减小的条件。递归在实际开发中有广泛的应用场景,但需要注意性能和堆栈溢出的问题。通过合理设计递归终止条件和优化递归算法,可以充分发挥递归的优势,解决复杂的问题。
在这里插入图片描述

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

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【二分答案 dp】 Bare Minimum Difference

分析&#xff1a; 首先我们能够得知这个优秀值具有单调性&#xff1a; 如果一个优秀值 x 1 x1 x1能够满足题目要求&#xff0c;那么任何 x ( x > x 1 ) x(x>x1) x(x>x1)显然都能符合要求 基于这一特性&#xff0c;我们想到二分答案 直接二分这个答案好像难以维护。 …

Php“梦寻”淘宝天猫商品详情数据接口,淘宝商品详情数据API接口,淘宝API接口申请指南(含代码示例)

淘宝商品详情接口 API 是开放平台提供的一种 API 接口&#xff0c;它可以帮助开发者获取淘宝商品的详细信息&#xff0c;包括商品的标题、描述、图片等信息。在淘宝电商平台的开发中&#xff0c;淘宝详情接口 API 是非常常用的 API&#xff0c;因此本文将详细介绍淘宝详情接口 …

【笔试强训选择题】Day37.习题(错题)解析

作者简介&#xff1a;大家好&#xff0c;我是未央&#xff1b; 博客首页&#xff1a;未央.303 系列专栏&#xff1a;笔试强训选择题 每日一句&#xff1a;人的一生&#xff0c;可以有所作为的时机只有一次&#xff0c;那就是现在&#xff01;&#xff01; 文章目录 前言一、Day…

macbookpro怎么删除软件没有鼠标

macbookpro怎么删除软件没有鼠标,macbookpro触摸板可以替代鼠标进行操作。左右键功能与鼠标相同&#xff0c;可用于执行删除操作。此外&#xff0c;还可以利用键盘上的Delete键来删除选中的文件。 删除软件方法 方法1、打开应用程序&#xff0c;键盘按住control&#xff0c;加点…

Android Automotive编译

系统准备 安装系统 准备一台安装Ubuntu系统的机器&#xff08;windows系统的机器可以通过WSL安装ubuntu系统&#xff09; 安装docker 本文使用docker进行编译&#xff0c;因此提前安装docker。参考网络链接安装docker并设置为不使用sudo进行docker操作。 参考链接&#xff…

E5071C是德科技网络分析仪

描述 E5071C网络分析仪提供同类产品中最高的RF性能和最快的速度&#xff0c;具有宽频率范围和多功能。E5071C是制造和R&D工程师评估频率范围高达20 GHz的RF元件和电路的理想解决方案。特点: 宽动态范围:测试端口的动态范围> 123 dB(典型值)快速测量速度:41毫秒全2端口…

什么是IIFE(Immediately Invoked Function Expression)?它有什么作用?

聚沙成塔每天进步一点点 ⭐ 专栏简介⭐IIFE 的基本语法⭐IIFE 的主要作用⭐如何使用 IIFE 来创建私有变量和模块封装⭐ 写在最后 ⭐ 专栏简介 前端入门之旅&#xff1a;探索Web开发的奇妙世界 记得点击上方或者右侧链接订阅本专栏哦 几何带你启航前端之旅 欢迎来到前端入门之旅…

界面控件DevExpress WinForms工具栏菜单组件,模拟流行办公软件!

DevExpress WinForms的工具栏和菜单组件灵感来自于Microsoft Office&#xff0c;并针对WinForms开发人员进行了优化&#xff0c;可以帮助开发者快速模拟当下流行的办公软件应用程序。 DevExpress WinForms有180组件和UI库&#xff0c;能为Windows Forms平台创建具有影响力的业…

Matlab(画图进阶)

目录 大纲 1.特殊的Plots 1.1 loglog(双对数刻度图) ​1.3 plotyy(创建具有两个y轴的图形) 1.4yyaxis(创建具有两个y轴的图) 1.5 bar 3D条形图(bar3) 1.6 pie(饼图) 3D饼图 1.7 polar 2.Stairs And Ste阶梯图 3.Boxplot 箱型图和Error Bar误差条形图 3.1 boxplot 3.2 …

ASP.NET Core 中的 MVC架构

MVC 架构 MVC架构把 App 按照逻辑分成三层&#xff1a; Controllers&#xff0c;接收 http request&#xff0c;配合 model&#xff0c;通过http response 返回 view&#xff0c;尽量不做别的事Models, 负责业务逻辑&#xff0c;App 的状态&#xff0c;以及数据处理Views&…

借助AI分析哥斯拉木马原理与Tomcat回显链路挖掘

前言 本次分析使用了ChatGPT进行辅助分析&#xff0c;大大提升了工作效率&#xff0c;很快就分析出木马的工作流程和构造出利用方式。 分析 首先对该木马进行格式化,以增强代码的可读性。得到如下代码 <jsp:root xmlns:jsp"http://java.sun.com/JSP/Page" vers…

如何解决前端传递数据给后端时精度丢失问题

解决精度丢失 有时候我们在进行修改操作时&#xff0c;发现修改既不报错也不生效。我们进行排查后发现服务器端将数据返回给前端时没有出错&#xff0c;但是前端js将数据进行处理时却出错了&#xff0c;因为id是Long类型的&#xff0c;而js在处理后端返回给前端的Long类型数据…

职责链设计模式

职责链模式又叫命令链、CoR、Chain of Command、Chain of Responsibility。 该模式允许你将请求沿着处理者链进行发送&#xff0c;使多个对象都可以处理请求&#xff0c;每个对象有权决定处理或传递给下个节点。 客户端&#xff1a;用来定义职责链条。 处理者&#xff1a;声明…

OpenCV 07(图像滤波器)

一、卷积 什么是图片卷积? 图像卷积就是卷积核在图像上按行滑动遍历像素时不断的相乘求和的过程 步长 步长就是卷积核在图像上移动的步幅. 上面例子中卷积核每次移动一个像素步长的结果, 如果将这个步长修改为2, 结果会如何? 为了充分扫描图片, 步长一般设为1. padding …

更换 yum 阿里源 - 手把手教你怎么配置,在也不需要求别人了 - 看懂一个就相当于看懂了其他的linux系统

更换阿里源 我的是centos8 当然 centos7 也可以换 后面有更详细的怎么配 &#xff0c;再也不用求别人怎么弄了 最直接的方式 直接复制 执行 centos7 curl -o /etc/yum.repos.d/CentOS-Base.repo https://mirrors.aliyun.com/repo/Centos-7.repo或者 wget -O /etc/yum.repos.…

fastadmin 框架中图片点击放大

fastadmin的原生图片预览,重新打开一个窗口太麻烦&#xff0c;使用layui做一个弹窗式的图片预览 效果如下&#xff1a; 点击放大&#xff1a; 第一步&#xff1a;在backend-init.js文件中添加如下代码&#xff1a; $(body).on(click, [data-tips-image], function () {var…

Java进行多线程编程?(lambda表达式~)

本文标题&#xff1a;Java进行多线程编程&#xff1f;那么&#xff0c;Java为啥不学学如何进程多进程编程呢&#xff1f;&#xff1f;原因在于&#xff1a;Java圈子中不提倡多进程编程~~ 接下来&#xff0c;我们来写一个最为基础/入门的HelloWord程序来感受如何进行多线程~~ J…

leetcode:58. 最后一个单词的长度

题目&#xff1a; 函数原型&#xff1a; int lengthOfLastWord(char * s) 解析&#xff1a; 求最后一个单词的长度&#xff0c;我们有两种思路 第一种思路&#xff1a; 逆向求&#xff0c;先设置一个字符串下标index&#xff0c;定位到最后一个单词的最后一个字符。再一个设置长…

微服务-kubernetes安装

文章目录 一、前言二、kubernetes2.1、Kubernetes (K8S) 是什么2.1.1、主要特性&#xff1a;2.2.2、传统部署方式&#xff1a;2.2.3、虚拟机部署2.2.4容器部署2.2.5什么时候需要 Kubernetes2.2.6、Kubernetes 集群架构 三、kubernetes安装3.1、主节点需要组件3.1.1、设置对应主…

Mybatis传递实体对象只能直接获取,不能使用对象.属性方式获取

mybatis的自动识别参数功能很强大&#xff0c;pojo实体类可以直接写进mapper接口里面&#xff0c;不需要在mapper.xml文件中添加paramType,但是加了可以提高mybatis的效率 不加Param注解&#xff0c;取值的时候直接写属性 //这里是单参数&#xff0c;可以不加param&#xff01…