(四)JAVA学习笔记--Java流程控制

1. 用户交互Scanner

1.1 Scanner对象

1.1.1 定义

java.util.Scanner 是Java5 的新特征,我们可以通过Scanner 类来获取用户的输入。
注意:使用Scanner类,需要在最前面加上

import java.util.Scanner;

1.2.1 基本语法

Scanner s = new Scanner(System.in);

1.2.3 常见的Scanner类

1.判断是否还有输入数据:

  • hasNext() 判断接下来是否有非空字符.如果有,则返回true,否则返回false
  • hasNextLine() 如果此扫描器的输入中存在一行(包括空行),有则返回true,否则返回false

2.然后再进行读取:

  • next()

1、一定要读取到有效字符后才可以结束输入。
2、对输入有效字符之前遇到的空白,next() 方法会自动将其去掉。
3、只有输入有效字符后才将其后面输入的空白作为分隔符或者结束符。
4、next() 不能得到带有空格的字符串。

  • nextLine()

1、以Enter为结束符,也就是说 nextLine()方法返回的是输入回车之前的所有字符。
2、可以获得空白。

public class scanner {
    
    
    public static void main(String[] args) {
    
    
        Scanner scanner = new Scanner(System.in);
        int a = scanner.nextInt();
        System.out.println(a);
    }
}
public class scanner {
    
    
    public static void main(String[] args) {
    
    
        Scanner scanner = new Scanner(System.in);
        String a = scanner.nextLine();
        if (a .equals("a"))//a=="a"则打印No,因为比较的不是字符,而是地址
         {
    
    
            System.out.println("Yes");
        }
        else {
    
    
            System.out.println("No");
        }
    }
}

2. 顺序结构

2.1 定义

最简单的算法结构,由若干个依次执行的处理步骤组成的,他是任何一个算法都离不开的一种基本算法结构。

3. 选择结构

3.1 if选择结构

3.1.1 if单选择结构

  • 语法
 if(布尔表达式)//如果布尔表达式为true将执行的语句
  • 示例
import java.util.Scanner;
public class HelloWorld {
    
    
    public static void main(String[] args) {
    
    
      Scanner s = new Scanner(System.in);
      String s1 = s.next();
      if(s1.equals("1")){
    
    
          //equals()用于判断字符串是否相等,此处不可以写成s1==“1”
          System.out.println("true");
      }
        System.out.println("End");
    }
}

3.1.2 if双选择结构

  • 语法
if(布尔表达式){
    //如果布尔表达式的值为trueelse{
    
    
    //如果布尔表达式的值为false
}
  • 示例
import java.util.Scanner;
public class HelloWorld {
    
    
    public static void main(String[] args) {
    
    
        Scanner s = new Scanner(System.in);
        String s1 = s.next();
        if (s1.equals("1")) {
    
    
            //equals()用于判断字符串是否相等,此处不可以写成s1==“1”
            System.out.println("true");
        } else {
    
    
            System.out.println("End");
        }
    }
}

3.1.3 if多选择结构

  • 语法
if(布尔表达式1){
    //如果布尔表达式1的值为true执行代码else if(布尔表达式2){
    //如果布尔表达式2的值为true执行代码else if(布尔表达式3){
    //如果布尔表达式3的值为true执行代码else{
    
    
    //如果以上布尔表达式都不为true执行代码
}

3.1.4 if的嵌套结构

  • 语法
if(布尔表达式 1){
    
    
    //如果布尔表达式 1的值为true执行代码
    if(布尔表达式 2{
    
    
        //如果布尔表达式 2的值为true执行代码
    }
}

3.2 switch多选择结构

3.2.1 定义

  • switch相当于if else的另一种表达形式
  • switch可以使用byte,short,int,char,String,enum
    注: 1.每个表达式结束,都应该有一个break;
    2.String在Java1.7之前是不支持的, Java从1.7开始支持switch用String的,编译后是把String转化为hash值,其实还是整数

示例

import java.util.Scanner;
public class HelloWorld {
    
    
    public static void main(String[] args) {
    
    
        Scanner s = new Scanner(System.in);
        String s1 = s.next();
        String season = null;
        switch(s1){
    
    
            case "一月":
            case "二月":
            case "三月":
            season = "春天";
                break;
            case "四月":
            case "五月":
            case "六月":
                season = "夏天";
                break;
            case "七月":
            case "八月":
            case "九月":
                season = "秋天";
                break;
            case "十月":
            case "十一月":
            case "十二月":
                season = "冬天";
                break;
            default:
                season = "输入错误";
        }
        System.out.println(season);
    }
}

3.3 循环结构

3.3.1 while循环

  • 基本语法
while(布尔表达式){
    
    
    //循环内容
}
  • 只有布尔表达式为 true,循环就会一直执行下去。
  • 我们大多数情况是会让循环停止下来的,我们需要一个让表达式失败的方式来结束循环。
  • 少部分情况需要循环一直执行,比如服务器的请求响应监听等。
  • 循环条件一直未true就会造成无限循环【死循环】,我们正常的业务编程中应该尽量避免死循环,会影响程序性能或者造成程序卡死崩溃!

示例
计算1+2+3+…+100=?

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

3.3.2 do…while循环

  • 结构与while类似,不同点在于至少执行do后面的代码一次
do{
    
    
    //代码语句
    while(布尔表达式)
}

3.3.3 for循环

  • 虽然所有循环结构都可以用 while 或者 do…while 表达,但是Java提供了另外一种语句 ——for循环,使一些循环结构变得更加简单。
  • for循环语句是支持送代的一种通用结构,是最有效,最灵活的循环结构。
  • for循环执行的次数是在执行前就确定的。

语法:

for(初始化;布尔表达式;更新)//代码语句
  • 最先执行初始化步骤,可以声明一种类型,但可初始化一个或者多个循环控制变量,可以是空句。
  • 然后,检测布尔表达式的值,如果是true,循环体被执行,如果为false,循环终止,开始执行循环体后面的语句。
  • 执行一次循环后,更新循环控制变量(送代因子控制循环变量的增减)。
  • 再次检查布尔表达式,循环执行上面的过程。

练习1:计算0到100之间奇数和偶数的和

public class HelloWorld {
    
    
    public static void main(String[] args) {
    
    
        int evenSum=0;
        int oddSum=0;
        for (int i = 0; i <=100; i++) {
    
    
            if (i%2==0){
    
    
                jishu+=i;
            }
            else{
    
    
                oushu+=i;
            }
        }
        System.out.println("奇数的和为:"+evenSum);
        System.out.println("偶数的和为:"+oddSum);
    }
}

3.3.4 增强for循环

  • Java5 引入了一种主要用于数组集合的增强型 for 循环。
  • Java 增强 for 循环语法格式如下:
for(声明语句:表达式)
{
    
    
    //代码句子
}
  • 声明语句:声明新的局部变量,该变量的类型必须和数组元素的类型匹配。其作用域限定在循环语句块,其值与此时数组元素的值相等。
  • 表达式:表达式是要访问的数组名,或者是返回值为数组的方法。
import java.util.ArrayList;
import java.util.List;
/**
 * 增强for循环
 *
 */
public class ForTest01 {
    
    

    public static void main(String[] args) {
    
    
        List<String> list = new ArrayList<>();
        list.add("a");
        list.add("b");
        list.add("c");
        list.add("d");

        //增强for循环,优点是可以简化遍历	
        for(String s : list){
    
    
            System.out.println(s);
        }
    }

3.3.5 break、continue、goto关键字

  • break 强行退出循环,不执行剩余语句(switch)
  • continue 用于循环语句体中,用于终止某次循环过程,即跳过循环体中尚未执行的语句,接着进行下次是否执行循环的判定
  • goto关键字

对 Java 来说唯一用到标签的地方是在循环语句之前。而在循环之前设置标签的唯一理由是:我们希望在其中嵌套另一循环,由于 break 和 continue 关键字通常只中断当前循环,但若随同标签使用,它们就会中断到存在标签的地方。

public static void main(String[] args) {
    
    
    outer: for (int i=101;i<150;i++){
    
    
        for(int j=2;j<i/2;j++){
    
    
           if (i%j==0){
    
    
               continue outer;//满足条件后回到 outer 记录位置从新运行。
          }
        }
        System.out.println(i);
    }
}

示例:打印三角形

public class HelloWorld {
    
    
    public static void main(String[] args) {
    
    
        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();
        }
    }
    }

练习

1.寻找某两个数相除,其结果 离黄金分割点 0.618最近 分母和分子不能同时为偶数 分母和分子 取值范围在[1-20]

public class HelloWorld {
    
    
    public static void main(String[] args) {
    
    
 
        // 寻找某两个数相除,其结果 离黄金分割点 0.618最近
        //
        // 分母和分子不能同时为偶数
        // 分母和分子 取值范围在[1-20]
        int range = 20; // 取值范围
        float breakPoint = 0.618f; // 黄金分割点
 
        float minDiff = 100; // 离黄金分割点的差值
        int answerFenzi = 0; // 找到的分子
        int answerFenmu = 0; // 找到的分母
        for (int fenzi = 1; fenzi <= range; fenzi++) {
    
    
            for (int fenmu = 1; fenmu <= range; fenmu++) {
    
    
                // 分母和分子不能同时为偶数
                if (0 == fenzi % 2 & 0 == fenmu % 2)
                    continue;
 
                // 取值
                float value = (float) fenzi / fenmu;
                // 取离黄金分割点的差值
                float diff = value - breakPoint;
                // 绝对值
                diff = diff < 0 ? 0 - diff : diff;
 
                // 找出最小的差值
                if (diff < minDiff) {
    
    
                    minDiff = diff;
                    answerFenzi = fenzi;
                    answerFenmu = fenmu;
                }
            }
        }
        System.out.println("离黄金分割点(" + breakPoint + ")最近的两个数相除是:" + answerFenzi + "/" + answerFenmu + "="
                + ((float) answerFenzi / answerFenmu));
    }
}

2.水仙花数定义:

  1. 一定是3位数
  2. 每一位的立方,加起来恰好是这个数本身,比如153=111+555+3* 3*3
    寻找所有的水仙花数
public class HelloWorld {
    
    
    public static void main(String[] args) {
    
    
        for (int i = 0; i < 10; i++) {
    
    
            for (int j = 0; j < 10; j++) {
    
    
                for (int k = 1; k < 10; k++) {
    
    
                    int a = 100 * k + 10 * j + 1 * i;
                    if (a == i * i * i + j * j * j + k * k * k)
                        System.out.println("水仙数为:" + a);
                }
            }
        }
    }
}

猜你喜欢

转载自blog.csdn.net/CHAINQWE/article/details/115049827