首页 > 其他分享 >循环结构

循环结构

时间:2022-11-23 16:24:39浏览次数:35  
标签:int System while 循环 结构 public out

循环结构

while循环

  • while循环是最基本循环,它的结构为:

    while (布尔表达式){
       //循环内容
    }
  • 只要布尔表达式为true,循环就会一直执行下去。

  • 我们大多数情况是会让循环停止下来的,我们需要一个让表达式失效的方式来结束循环。

  • 少部分情况需要循环一直执行,比如服务器的请求响应监听等。

  • 循环条件一直为true就会造成无限循环【死循环】,我们应该尽量避免死循环。

    //输出1~100
    public class WhileDemo01 {
       public static void main(String[] args) {
           int i = 0;

           while (i < 100){
               i++;
               System.out.println(i);
          }
      }
    }
    //计算1+2+3+...+100=?
    public class WhileDemo02 {
       public static void main(String[] args) {
           int i = 0;
           int sum = 0;

           while (i <= 100){
               sum = sum + i;
               i++;
          }
           System.out.println(sum);
      }
    }

do...while循环

  • 对于while语句而言,如果不满足条件,则不能进入循环,但有时候我们需要即使不满足条件,也至少执行一次。

  • do...while循环和while循环相似,不同的是,do...while循环至少执行一次。

    do {
       //代码语句
    } while (布尔表达式);
  • while和do...while的区别:

    • while先判断后执行,do...while是先执行后判断!

    • do...while总是保证循环体会被至少执行一次!

      //计算1+2+3+...+100=?
      public class DoWhileDemo01 {
         public static void main(String[] args) {
             int i = 0;
             int sum = 0;

             do {
                 sum = sum + i;
                 i++;
            }while (i <= 100);

             System.out.println(sum);
        }
      }
      //while和do...while的区别:
      public class DoWhileDemo02 {
         public static void main(String[] args) {
             int a = 0;

             while (a < 0){
                 System.out.println(a);
                 a++;
            }

             System.out.println("====================");

             do {
                 System.out.println(a);
                 a++;
            } while (a < 0);
        }
      }

for循环

  • for循环语句是支持迭代的一种通用结构,是最有效、最灵活的循环结构

  • for循环执行的次数是在执行前就确定的。语法格式如下:

    for (初始化;布尔表达式;迭代) {
       //代码语句
    }
    //计算1~100的奇数和以及偶数和
    public class ForDemo01 {
       public static void main(String[] args) {
           int oddNum = 0;
           int evenNum = 0;

           for (int i = 0; i <= 100; i++) {
               if (i % 2 != 0){//判断是否为奇数
                   oddNum += i;
              }else {
                   evenNum += i;
              }
          }

           System.out.println("奇数和为:"+oddNum);
           System.out.println("偶数和为:"+evenNum);
      }
    }
    //输出1~1000之间能被5整除的数,并且每行输出3个
    public class ForDemo02 {
       public static void main(String[] args) {
           for (int i = 0; i <= 1000; i++) {
               if (i % 5 ==0){
                   System.out.print(i +"\t");
              }
               if (i % (5 * 3) == 0){//换行
                   System.out.println();
                   //System.out.print("\n");
              }
          }

           //println 输出完会换行
           //print   输出完不会换行
      }
    }
    //打印九九乘法表
    public class ForDemo03 {
       public static void main(String[] args) {
           for (int j = 1; j <= 9; j++) {
               for (int i = 1; i <= j; i++) {
                   System.out.print(i + " * " +j+ " = " +(i * j) +"\t");
              }
               System.out.println();
          }
      }
    }

增强for循环

  • 主要用于数组或集合

  • 语法格式:

    for (声明语句 : 表达式) {
       //代码语句
    }
  • 声明语句:声明新的局部变量,该变量的类型必须和数组元素的类型匹配。

  • 表达式:表达式是要访问的数组名,或者是返回值为数组的方法。

    public class ForDemo05 {
       public static void main(String[] args) {
           int[] numbers = {10,20,30,40,50};//定义了一个数组
           
           //遍历数组的元素
           for (int x : numbers){
               System.out.println(x);
          }
      }
    }

标签:int,System,while,循环,结构,public,out
From: https://www.cnblogs.com/my-ytt/p/16918663.html

相关文章

  • 数据结构与算法测试题
    1.完全二叉树的第5层有9个节点,该完全二叉树总计有多少个节点( B   ).A.41B.24C.40D.25完全二叉树,说明前四层都是满结点,第五层有九个结点,故有:2^4 -1=15     ......
  • 数据结构习题整理(4.0)
    42.试着写出一个判定给定二叉树是否为二叉排序树的算法。设此二叉树以二叉链表作存储结构,且树中结点的关键字均不同。intisbstree(bitreet)/*判断是否为二叉排序树*/{if(t......
  • java和设计模式(结构模式)
        在设计模式中,有一类设计模式是比较有意思的,但是关注的人不多。这就是结构模式。如果说创建模式的重点是如何创建出实例对象,那么结构模式的特点就是利用类、示例......
  • asm实现双循环
    我们用dx,实现cx数据的临时存储;dxbeusedfordoubleloops,itcansavethevalueofcx;doubleloopassumecs:codecodesegmentmovcx,2hmovax,0h......
  • Composite 组合模式(结构型模式)
    意图:将对象组成树形结构以表示“部分——整体”的层次结构。Composite使得对单个对象和组合对象的使用具有一致性。要点:1、Composite模式采用树形结构来实现普遍存在的对象......
  • Bridge 桥接模式(结构型模式)
    意图:将抽象部分与实现部分分离,使它们都可以独立的变化。要点:1、Bridge模式使用“对象间的组合关系”解耦了抽象和实现之间固有的绑定关系,使得抽象和实现可以沿着各自的维度......
  • Adapter 适配器模式(结构型模式)
    意图:将一个类的接口转换成客户希望的另一个接口。Adapter模式使得原本由于接口不兼容而不能一起工作的那些类可以一起工作。要点:1、Adapter模式......
  • 数据结构初阶--顺序表(讲解+C++类模板实现)
    顺序的概念与结构顺序表是用一段物理地址连续的存储单元依次存储数据元素的线性结构,一般情况下采用数组存储。在数组上完成数据的增删查改。一般分为两种:静态顺序表和动......
  • 随想录(为什么循环队列具有先天的并行性)
       循环队列是很多人喜欢用的一种数据结构。本着先来先服务的特性,循环队列是一种十分简单、健壮的数据结构。不像链表、二叉树,如果使用不慎,就会造成很大的麻烦,但是在循......
  • 算法基础 数据结构
    单调队列概念单调队列题目154.滑动窗口题目描述给定一个大小为n≤106的数组。有一个大小为k的滑动窗口,它从数组的最左边移动到最右边。你只能在窗口中看到k......