JavaSE——Day3

1、流程控制

1.1 接受用户输入

在Java语言中有一个工具类Scanner,是一个简单的文本扫描程序,可以使用正则表达式解析基本类型和字符串,一般用户输入的键盘命令通过以下代码执行:

Scanner sc = new Scanner(System.in);
     String s = sc.next();  

关于Scanner类更详细的地方可以寻找API查看。

1.2 执行结构概述

任何简单或复杂的算法都可以由顺序结构、分支结构和循环结构这三种基本结构组合而成。
顺序结构:顺序结构是一种基本的控制结构,它按语句出现的顺序执行操作
分支结构:分支结构又被称为选择结构,根据条件成立与否来执行操作
循环结构:循环结构是一种重复的结构,如果条件成立,它会重复执行某一循环体,直到出现不满足的条件为止

1.3 执行结构

1.3.1 if条件语句

if条件结构满足条件判断之后再处理:格式
if(条件语句){……}
if(条件语句){……} else if(条件语句){……}
if(条件语句){……} else if(条件语句){……}else{……}

在这里插入图片描述

1.3.2 switch结构

格式:
switch(表达式){
case 取值:
break;
case 取值:
break;
default 语句块 n+1;break;

规则:
表达式的返回值必须是:int、byte、char、short、String;
case子句中的取值必须是常量,且所有case子句中的取值应该是不同的;
default子句是可选的;
break语句是用来执行一个case分支后使程序跳出switch语句,如果没写break,则继续往下面执行;
case后面的执行体可写可不写。

public static void main(String[] args) {
        while (true){
        System.out.println("请输入月份(1-12),来判断季节");
        Scanner inputMonth = new Scanner(System.in);
        int month = inputMonth.nextInt();
        if(month==0) break;
        switch (month) {
            case 12:
            case 1:
            case 2:
                System.out.println("冬季");
                break;

            case 3:
            case 4:
            case 5:
                System.out.println("春季");
                break;

            case 6:
            case 7:
            case 8:
                System.out.println("夏季");
                break;

            case 9:
            case 10:
            case 11:
                System.out.println("秋季");
                break;
             default:
             	System.out.println("输入有误,请重新输入");
        }
    }}
1.3.2 循环语句-while循环

符合条件,循环执行;否则循环结束
特点:先判断,再执行
ps:一定要检查跳出语句能否正常执行,否则会造成死循环

语法:
while(条件表达式){
//语句块
}

1.3.3 循环语句-do-while循环

符合条件,循环执行;否则循环结束
特点:先执行,再判断
ps:一定要检查跳出语句能否正常执行,否则会造成死循环

语法:
do{
//语句块
}while(条件表达式)

1.3.4 循环语句-for循环

for 格式:
for(定义循环变量;判断循环条件;更新循环变量){
//循环体
}
特殊格式:

for (;;){
            System.out.println("1");//一直输出1
        }
for (System.out.println("1");true;System.out.println(2)){
            System.out.println(3);//输出结构是1 3 2 3 2 3 2 ……
        }

ps:两个分好之间如果不填写默认为true,是一个死循环。

1.4 break与continue

break是用于终止本轮所有次循环,即不执行本次循环中break后面的语句,直接跳出循环
continue是用于终止本轮本次循环,即本次循环中continue后面的代码不执行,进入下一个循环入口的判断

在这里插入图片描述

1.5 如何结束多重循环

给想要退出的循环加一个别名:例
在这里插入图片描述

1.6 判断用户输入类型

如果要求输入数字时,用户输入非数字,则会报错,InputMismatchException 。加一个类型判断则满足交付标准
在这里插入图片描述

2、数组

2.1 数组格式

数组是相同数据类型的多个数据的容器。这些元素是线性顺序排列。
创建格式:
数据类型[] 数组名=new 数据类型[数组长度];(常用)
数据类型[] 数组名={数据1,数据2……}(常用)
数据类型[] 数组名;(不常用)后续添加数据需使用new关键字
数据类型[] 数组名=new 数据类型[数组长度]{数据1,数据2……};(不常用)

通过下标操作数组数据的方式
数组下标从0开始。
1、给数据某个下标赋值:数组名称[下标]=值;
2、从数组某个下标取值:数组名称[下标]

如何获取数组长度: 数组名称.length

2.2 数组问题

1、数组下标越界问题
2、空指针异常问题(数组未赋值)

2.3数组常用算法

冒泡排序:
原理:

  • 比较相邻的元素。如果第一个比第二个大,就交换他们两个。
  • 对每一对相邻元素做同样的工作,从开始第一对到结尾的最后一对。在这一点,最后的元素应该会是最大的
    数。
  • 针对所有的元素重复以上的步骤,除了最后一个。
  • 持续每次对越来越少的元素重复上面的步骤,直到没有任何一对数字需要比较。

升序排列的口诀:
N个数字来排队
两两相比小靠前,
外层 循环length-1
内层循环length-i-1

降序排序的口诀:
N个数字来排队
两两相比大靠前,
外层 循环length-1
内层循环length-i-1

public static void main(String[] args) {
        int[] nums = {1, 3, 9, 5, 6, 7, 15, 4, 8};
        int temp;
        for (int i = 0; i < nums.length-1; i++) {
            for (int j = 0; j < nums.length - i-1; j++) {
                if(nums[j]>nums[j+1]){
                    temp=nums[j];
                    nums[j]=nums[j+1];
                    nums[j+1]=temp;
                }
            }
        }
        for (int i = 0; i < nums.length; i++) {
            System.out.println(nums[i]);
        }
    }

二分查找(折半查找)
概述:二分查找也称折半查找(Binary Search),它是一种效率较高的查找方法。但是,二分查找要求数组数据必须采用顺
序存储结构有序排列。
原理:
首先,假设数组中元素是按升序排列,将数组中间位置的数据与查找数据比较,如果两者相等,则查找成功;否则利用
中间位置记录将数组分成前、后两个子数组,如果中间位置数据大于查找数据,则进一步查找前子数组,否则进一步查
找后子数组。
重复以上过程,直到找到满足条件的数据,则表示查找成功,
直到子数组不存在为止,表示查找不成功
在这里插入图片描述
步骤:1、确定查找的范围 最小~最大
2、计算中间下标 (最小下标+最大下标)/2
3、比较中间下标数据,中间数据较大,则最大下标等于中间下标-1
比较中间下标数据,中间数据较小,则最小下标等于中间下标+1
4、当最小下标大于最大下标时,说明数据不存在

public static void main(String[] args) {
        int[] nums = {1, 3, 9, 5, 6, 7, 15, 4, 8};
        //冒泡排序
        int temp;
        for (int i = 0; i < nums.length - 1; i++) {
            for (int j = 0; j < nums.length - i - 1; j++) {
                if (nums[j] > nums[j + 1]) {
                    temp = nums[j];
                    nums[j] = nums[j + 1];
                    nums[j + 1] = temp;
                }
            }
        }
        for (int i = 0; i < nums.length; i++) {
            System.out.print(nums[i]+" ");
        }
        //二分查找
        int n = 6;
        int minIndex = 0;//最小范围下标
        int maxIndex = nums.length - 1;//最大范围下标
        int centerIndex = (minIndex + maxIndex) / 2;//中间数据下标
        while (true) {
            if (nums[centerIndex] > n) {
                //中间数据大于n
                maxIndex=centerIndex-1;
            } else if (nums[centerIndex] < n) {
                //中间数据小于n
                minIndex=centerIndex+1;
            } else {
                //中间数据等于n
                break;
            }
            if (minIndex>maxIndex){
                centerIndex=-1;
            }
            //更新中间数据下标
            centerIndex=(minIndex+maxIndex)/2;
        }
        System.out.println("\n"+n+"排序后下标是"+centerIndex);

    }

2021年8月16日

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

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值