Java流程控制

java流程控制

Scanner

next()

  • 一定要读取到有效字符后才可以结束输入

  • 对输入有效字符之前遇到的空白,next()方法会自动将其去掉

  • 只有输入有效字符后才能将其后面输入的空白作为分割符或者结束符

  • next() 不能得到代用空格的字符串

    package com.split.scanner;
    
    import java.util.Scanner;
    
    public class Demon01 {
        public static void main(String[] args) {
    
            //创建一个扫描器对象,用于接受键盘数据
            Scanner scanner = new Scanner(System.in);
            System.out.println("使用next方式接收");
    
            //判断用户有没有输入字符串
            if (scanner.hasNext()){
                //使用next方式接收
                String str =scanner.next();
                System.out.println("输入的内容为"+str);
            }
            //凡是属于IO流的类如果不关闭会一直占用资源,要养成好习惯用完应关闭
            scanner.close();
    
        }
    }
    
    

nextLIne

  • 以回车为结束符,nextLine()方法返回的是输入回车之前的所有字符
  • 可以获得空白
package com.split.scanner;

import java.util.Scanner;

public class Demon02 {
    public static void main(String[] args) {
        Scanner scanner= new Scanner(System.in);
        System.out.println("使用nextLine方式接收");

        if(scanner.hasNextLine()){
            String str= scanner.nextLine();
            System.out.println("输入的内容为"+str);
        }
        scanner.close();
    }
}

进阶使用

package com.split.scanner;

import java.util.Scanner;

public class Demon04 {
    public static void main(String[] args) {
        Scanner scanner =new Scanner(System.in);
        // 从键盘接受数据
        int i=0;
        float f=0.0f;
        System.out.println("请输入整数");
        //如果。。。 否则。。。
        if (scanner.hasNextInt()){
            i=scanner.nextInt();
            System.out.println("整数数据"+i);
        }
        else {
            System.out.println("输入的不是一个整数数据");
        }
        System.out.println("请输入小数");
        //如果。。。 否则。。。
        if (scanner.hasNextFloat()){
            f=scanner.nextFloat();
            System.out.println("小数数据"+f);
        }
        else {
            System.out.println("输入的不是一个小数数据");
        }


        scanner.close();
    }
}

输入几个数字,并求其总和和平均数,每输入一个数字用回车确认,用过输入的非数字来结束输入并输出执行结果

package com.split.scanner;

import javax.crypto.spec.PSource;
import java.util.Scanner;

public class Demon05 {
    public static void main(String[] args) {
        //输入几个数字,并求其总和和平均数,每输入一个数字用回车确认,用过输入的非数字来结束输入并输出执行结果
        Scanner scanner = new Scanner(System.in);
        //和
        double sum=0;
        //计算输入了多少个数字
        int m=0;
        //通过循坏来判断是否还有输出,并在里面对每一次进行求和和统计
        while (scanner.hasNextDouble()) {
            double x = scanner.nextDouble();
            m=m+1;// m++
            sum=sum+x;
            System.out.println("你输入第"+m+"个数据"+"当前的结果为"+sum);
        }
        System.out.println("个数的和为"+sum);
        System.out.println("平均数为"+(sum/m));
        scanner.close();
    }
}

顺序结构

他是任何一个算法都离不开的一种基本算法结构

package com.split.struct;

public class ShunXunDemon01 {
    public static void main(String[] args) {
        System.out.println("heelo1");
        System.out.println("heelo2");
        System.out.println("heelo3");
        System.out.println("heelo4");
        System.out.println("heelo5");
    }
}

选择结构

if

if单选择结构

package com.split.struct;

import java.util.Scanner;

public class IfDemon01 {
    public static void main(String[] args) {
        Scanner scanner =new Scanner(System.in);

        System.out.println("请输入一个内容:");
        String s = scanner.nextLine();

        //判断字符串是否相等
        if(s.equals("Hello")){
            System.out.println(s);
        }
        System.out.println("End");

        scanner.close();
    }
}

if双选择结构

package com.split.struct;

import java.util.Scanner;

public class IfDemon02 {
    public static void main(String[] args) {
        //考试分数大于60分及格,小于六十分不及格
        Scanner scanner =new Scanner(System.in);
        System.out.println("请输入一个分数");
        int score = scanner.nextInt();
        if(score>=60){
            System.out.println("及格");
        }
        else {
            System.out.println("不及格");
        }
        scanner.close();
    }
}

if多选择结构

  • if 语句最多有一个else语句,else语句在所有的else if 语句之后
  • if 语句可以有若干个else if 语句,他们必须在else之间
  • 一旦其中一个else if 语句检测为true,其他的else if 以及else 语句都将其跳过执行
package com.split.struct;

import java.util.Scanner;

public class IfDemon03 {
    public static void main(String[] args) {
        Scanner scanner =new Scanner(System.in);
        System.out.println("请输入一个分数");
        int score = scanner.nextInt();
        if (score==100){
            System.out.println("恭喜满分");
        }
        else if (score>=60&&score<100){
            System.out.println("及格");
        }
        else if(score<0||score>100){
            System.out.println("你在逗我");
        }
        else{
            System.out.println("不及格");
        }
        scanner.close();
    }
}

嵌套if结构

switch

反编译

//
// Source code recreated from a .class file by IntelliJ IDEA
// (powered by FernFlower decompiler)
//

package com.split.struct;

public class SwitchDemon01 {
    public SwitchDemon01() {
    }

    public static void main(String[] args) {
        char grade = 70;
        switch(grade) {
        case 65:
            System.out.println("优秀");
            break;
        case 66:
            System.out.println("良好");
            break;
        case 67:
            System.out.println("及格");
            break;
        case 68:
            System.out.println("再接再厉");
            break;
        case 69:
            System.out.println("挂科");
            break;
        default:
            System.out.println("未知等级");
        }

    }
}

package com.split.struct;

public class SwitchDemon01 {
    public static void main(String[] args) {
        char grade = 'F';
        switch (grade){
            case 'A':
                System.out.println("优秀");break;
            case 'B':
                System.out.println("良好");break;
            case 'C':
                System.out.println("及格");break;
            case 'D':
                System.out.println("再接再厉");break;
            case 'E':
                System.out.println("挂科");break;
            default:
                System.out.println("未知等级");break;
        }
    }
}

package com.split.struct;

public class SwitchDemon02 {
    public static void main(String[] args) {
        // JDK7的新特性,表达式可以是字符串
        //字符串本质还是数字
        
        //反编译 java---class(字节码文件)-----反编译(IDEA)
        String name = "Split";
        
        switch (name){
            case "Split" :
                System.out.println("Split");break; 
            case "split" :
                System.out.println("大写首字母");break;
            default:
                System.out.println("不知道你说谁");break;
        }
    }
}

循环结构

while循环

  • 只要布尔表达式为true,循坏就还会一直执行下去
  • 我们大多数情况下会让循环停止下来的,我们需要一个表达式失效的方式来结束循坏
package com.split.struct;

public class WhileDemon01 {
    public static void main(String[] args) {
        //输出一到一百
        int i=0;
        while(i<100){
            i++;
            System.out.println(i);
        }
    }
}

死循坏

package com.split.struct;

public class WhileDemon02 {
    public static void main(String[] args) {
        //死循坏
        while (true){
            // 等待客户端聊天
            //闹钟
        }
    }
}

从一加到一百

package com.split.struct;

public class WhileDemon03 {
    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 循坏

即使不满足条件,也要执行一次

先执行,后判断

package com.split.struct;

public class DoWhileDemon01 {
    public static void main(String[] args) {
        int i=0;
        int sum=0;
        do {
            sum=sum+i;
            i++;
        }while (i<=100);
        System.out.println(sum);
    }
}

package com.split.struct;

public class DoWhileDemon02 {
    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);
        }
        while (a<0);
    }
}

For 循坏

for循坏语句是支持迭代的一种通用工具,是最有效,最灵活的循坏结构

for循坏执行的次数是执行前就确定的

  • 快捷键 100.for= for(i=0;i<100;i++){}
package com.split.struct;

public class ForDemon01 {
    public static void main(String[] args) {
        int a =1;  //初始化条件

        while(a<100){   //条件判断
            System.out.println(a);// 循坏体
            a+=2; //迭代
        }
        System.out.println("while循坏结束");

        for(int i=1;i<=100;i++){
            System.out.println(i);
        }
        System.out.println("for循坏结束");
        
        //死循坏
        for(;;){}
    }
}

package com.split.struct;

public class ForDemon02 {
    public static void main(String[] args) {
        // 练习一:计算0到100之间奇数和偶数的和;

        int oddsum=0;
        int evensum=0;

        for (int i = 0; i < 100; i++) {
            if (i%2!=0){
                oddsum+=i;
            }
            else {
                evensum+=i;
            }
        }
        System.out.println("奇数的和"+oddsum);
        System.out.println("偶数的和"+evensum);

    }
}

package com.split.struct;

public class ForDemon03 {
    //1到1000能被5整除的数,并且每行输出3个
    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.println("\n");
            }
        }
    }


}

99乘法表

package com.split.struct;
// 99乘法表
public class ForDemon04 {
    public static void main(String[] args) {
        for (int j = 0; j <= 9; j++) {
            for (int i = 1; i <= j; i++) {
                System.out.print(j+"*"+i+"="+(j*i)+"\t");
            }
            System.out.println("");
        }

    }
}

增强for循坏

package com.split.struct;

public class ForDemon05 {
    public static void main(String[] args) {
        int[] numbers = {10, 20, 30, 40, 50};
        for (int i = 0; i < 5; i++) {
            System.out.println(numbers[i]);
        }
        System.out.println("----------------------------------------------");
        //遍历数组的元素
        for (int x:numbers) {
            System.out.println(x);
        }
    }
}

Break Continue goto

  • break在任何循坏语句的主体部分,均可用break控制循坏的流程,break用于强行退出循坏,不执行循坏中剩余的语句。(break语句也在switch语法中使用)
  • continue 语句用在循坏体语句中,用于终止某次循坏过程,即跳过循坏体中尚未执行的语句,接着进行下一次是否执行循坏的判定。
package com.split.struct;

public class BreakDemon01 {
    public static void main(String[] args) {
        int i=0;
        while (i<100){
            i++;
            if (i==30){break;}
        }
    }
}

package com.split.struct;

public class ContinueDemon01 {
    public static void main(String[] args) {
        int i=0;
        while (i<100){
            i++;
            if (i%10==0){
                System.out.println();
                continue;
            }
            System.out.println(i);
        }
    }
}

package com.split.struct;

public class LableDemon01 {
    public static void main(String[] args) {
        //打印0到100之间的质数

        //在大于一的自然数,只有1和他本身整数的数叫质数
        int count = 0;
        outer: for (int i=101;i<150;i++){
            for (int j=2;j<i/2;j++){
                if (i%j==0){
                    continue outer;
                }
            }
            System.out.println(i+" ");
        }
    }
}

  • 打印三角形
package com.split.struct;

public class TextDemon01 {
    public static void main(String[] args) {
        //打印三角形   5行
        for (int i = 1; i <= 5; i++) {
            for (int j=5;j>=i;j--){
                System.out.print(" ");
            }
            for (int j=1; j<=i;j++){
                System.out.print("*");
            }
            for (int j=1;j<i;j++){
                System.out.print("*");
            }
            System.out.println();
        }
    }
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值