5.29_Java程序流程控制

news2024/11/8 11:12:29

CSDN     同C语言的流程同

1、补充:

1、switch使用时的注意事项

1、表达式只能是byte、short、int、char,JDK5开始支持枚举,JDK7开始支持String、不支持double、float、long

switch里面是做分支匹配,也就是可以出现很多分支,如果弄得范围很大,不可能出现这么多分支,int的范围都很大了,所以没有必要long搞这么多分支 。

double类型的数据它运算的时候可能是不精确的

默认double运算是不精确的,正是由于double运算不精确,自己计算的时候肯定会以为b是等于0.3,里面自己就会写个case 0.3;,但是这个b最后算出来的结果不是0.3,走不了这个分支,所以Java知道有这个问题,索性不支持double类型。 

2、case给出的值不允许重复,且只能是字面量,不能是变量

会不知道走哪个分支,会冲突

以为这个变量的值是可以改的,万一这个d改成了20呢,又跟下面的重复报错吗,不会的,所以就要一个确定值,定死了。

2、while循环和for循环

知道循环几次用for,不知道循环几次建议用while

案例:纸张折叠成珠穆朗玛峰的高度

需求:世界上最高山峰珠穆朗玛峰高度是:8848.86米=8848860毫米,假如我有一张足够大的纸,它的厚度时0.1毫米。请问:该纸折叠多少次,可以折成珠穆朗玛峰的高度,

一开始不知道要循环多少次使用while

分析:

1、定义变量存储珠穆朗玛峰的高度,纸张的高度

2、使用while循环来控制纸张折叠,循环条件是(纸张厚度<山峰高度),循环每执行一次,就代表纸张折叠一次,并把纸张厚度变为原来的两倍。

3、循环外定义计数变量count,循环每折叠一次纸张,让count变量+1;

package com.branch;

public class WhileTest2 {
    public static void main(String[] args) {
        double peakHeight=8848860;
        double paperThickness=0.1;
        int count=0;
        while(paperThickness<peakHeight)
        {
            paperThickness=paperThickness*2;
            count++;
        }
        System.out.println("需要折叠" + count + "次");
        System.out.println("最终纸张的厚度" + paperThickness);
    }
}

2.Random的使用

作用:生成随机数

package com.random;

import java.util.Random;

public class RandomDemo1 {
    public static void main(String[] args) {
        //1、导包
        //2、创建一个Random对象,用于生成随机数
        Random r=new Random();
        //3、调用Random提供的功能:nextInt得到随机数

        for (int i=0;i<=20;i++) //控制下面这串代码重复执行20次
        {
            int data=r.nextInt(10);//0~9
            System.out.println(data);
        }

    }
}

 结果:

注意:

  • nextInt(n)功能只能生成:0~n-1之间的随机数,不包含n  ((10):0,1,2,3,4,5,6,7,8,9)

Random生成指定区间随机数

例如:要生成1~10之间的随机数。

 

结果:

补充:

可以直接写区间

int data3=r.nextInt(10,31);//10-30

3、案例:猜数字游戏

需求

  • 随机生成一个1-100之间的数据,提示用户猜测,猜大提示过大,猜小提示过小,直到猜中结束游戏。

分析:

1、先随机生成一个1-100之间的数据

2、定义一个死循环让用户可以一直猜测

3、在死循环中,每次提示用户输入一个猜测的数字,猜大提示过大,猜小提示过小,猜中则结束游戏。

package com.random;

import java.util.Random;
import java.util.Scanner;

public class RandomTset2 {
    public static void main(String[] args) {
        //1、随机产生1-100
        Random r=new Random();
        int luckNumber=r.nextInt(100)+1;
        //2、定义一个死循环让用户可以一直猜测
        Scanner sc=new Scanner(System.in);
        while(true)
        {
            System.out.println("请输入你猜测的数据");
            //接收用户输入的数据,用扫描器
            int guessNumber=sc.nextInt();
            //3、判断用户猜测的数字与luckNumber的大小情况
            if(guessNumber>luckNumber)
            {
                System.out.println("猜测的过大");
            }
            else if(guessNumber<luckNumber)
            {
                System.out.println("猜测的过小");
            }
            else
            {
                System.out.println("猜对了");
                break;//结束死循环
            }

        }
    }
}

4、数组

4.1数组的定义和访问

4.1.1 静态初始化数组

静态初始化数组:定义数组的时候直接给数组赋值

静态初始化数组的格式:

注意:

  • “数据类型[ ] 数组名”也可以写成“数据类型 数组名[ ]”
  • 什么类型的数组只能存放什么类型的数据
package com.define;

public class ArrayDemo1 {
    public static void main(String[] args) {
        //静态初始化数组
        //1、数据类型[] 数组名 = new 数据类型[]{元素1,元素2,元素3......}
        int[] age= new int[]{10,28,15,18};
        double[] scorces = new double[]{89.5,99.5,68.5,99};

        //2、简化版
        //数据类型[] 数组名 = {元素1,元素2,元素3......}
        int[] age1= {10,28,15,18};
        double[] scorces1 ={89.5,99.5,68.5,99};

        //“数据类型[ ] 数组名”也可以写成“数据类型 数组名[ ]”
        int age2[] = {10,28,15,18};
        double scorces2[] ={89.5,99.5,68.5,99};
    }
}

 数组在计算机中的基本原理

 

注意:数组变量名中存储的是数组在内存中的地址,数组是一种引用数据类型 

4.1.1.1数组的访问

 数组名[索引]  (索引也就是C语言中数组的下标)

数组的长度属性:length

//获取数组的长度(也就是数组元素的个数)

System.out.println(age.length);//3
package com.define;

public class ArrayDemo2 {
    public static void main(String[] args) {
        int[] arr={12,34,24};
        //1、访问数组的全部数据
        System.out.println(arr[0]);
        System.out.println(arr[1]);
        System.out.println(arr[2]);
        //System.out.println(arr[3]);//会越界
        System.out.println("---------------------------------------");
        //2、修改数组中的数据
        arr[0]=66;
        arr[2]=100;
        System.out.println(arr[0]);
        System.out.println(arr[1]);
        System.out.println(arr[2]);
        System.out.println("---------------------------------------");
        //3、访问数组的元素个数:数组名.length
        System.out.println(arr.length);
        System.out.println("---------------------------------------");
        //技巧:获取数组的最大索引 数组名.length-1  前提是数组中存在数据
        System.out.println(arr.length - 1);
    }
}

结果:

4.1.1.2数组的遍历

遍历:就是一个一个数据的访问

求和、元素搜索、找最大值、找最小值等情况下会用到数组的遍历

package com.define;

public class ArrayDemo3 {
    public static void main(String[] args) {
        int[] ages={15,36,23};
        //           0  1  2
        /*System.out.println(ages[0]);
        System.out.println(ages[1]);
        System.out.println(ages[2]);*/

        /*for(int i=0;i<3;i++)
        {
            //i=0,1,2
            System.out.println(ages[i]);
        }*/

        for(int i=0;i< ages.length;i++)
        {
            //i=0,1,2
            System.out.println(ages[i]);
        }
        //技巧
        for (int i = 0; i < ages.length; i++) {
            
        }
    }
}

4.1.1.3案例训练 

数组遍历--求和

需求:

  • 某部门5名员工的销售额分别是16、26、36、6、100,请计算出他们部门的总销售额

分析:

1、把这5个数据拿到程序中去  -->使用数组

2、遍历数组中的每个数据,然后在外面定义求和变量把他们累加起来

 

package com.define;

public class ArrayDemo4 {
    public static void main(String[] args) {
        //1、定义一个数组存储5名员工的销售额
        int[] money={16,26,36,6,100};
        //            0  1  2 3  4

        //3、定义一个变量用于累加求和
        int sum=0;

        //2、遍历数组中的每个数据
        for (int i = 0; i < money.length; i++) {
            sum+=money[i];
        }
        System.out.println("员工的销售总额:" + sum);
    }
}

结果:

4.1.2动态初始化数组

数组的动态初始化:定义数组的时候先不加入具体的元素值,只确定数组存储的数据类型和长度

数组的动态初始化的格式:

数据类型[ ]  数组名 = new 数据类型[长度];

int[ ] arr = new int[3]; 

先往里面存默认值,int类型默认值是0

 

后赋值

arr[0]=10;

System.out.println(arr[0]);//10

 提示:

静态初始化和动态初始化数组的写法是独立的,不可以混用。

 动态初始化数组元素默认规则:

 把这个字符(chars[0])取出来之后,把他转成真正的数据,int类型

 适合场景:
  • 动态初始化:适合开始不知道具体元素值,只知道元素个数的场景
  • 静态初始化:适合一开始就知道要存入哪些元素值得场景 
 案例训练

需求:

  • 某歌唱比赛,需要开发一个系统:可以录入6名评委的打分,录入完毕后立即输出平均分作为选手得分。

分析: 

1、 6名评委的打分是后期录入的,一开始不知道具体分数-->动态初始化的数组存分数

2、遍历数组中的每个位置,每次提示用户录入一个评委的分数,并存入到数组对应的位置

3、遍历数组元素求和,最终得到的值算平均分打印出来

package com.define;

import java.util.Scanner;

public class ArrayTest6 {
    public static void main(String[] args) {
        //1、
        double[] scores=new double[6];
        //2、
        Scanner sc=new Scanner(System.in);
        for (int i = 0; i < scores.length; i++) {
            //i= 0 1 2 3 4 5
            System.out.println("请您输入当前第" + (i + 1) + "名评委的分数");
            double score=sc.nextDouble();
            scores[i]=score;
        }
        //3、
        double sum=0;
        for (int i = 0; i < scores.length; i++) {
            sum+=scores[i];
        }
        System.out.println("选手最终得分是:" + sum / scores.length);
    }
}

结果:

4.2数组的内存执行原理

1、数组的执行原理,Java程序的执行原理

Java内存分配介绍:

  • 方法区
  • 本地方法栈
  • 程序计数器

运行一个Java程序,主要看JVM中包含的方法区、栈内存、堆内存这三个内存区域 

 

 

 

2、多个变量指向同一个数组的问题

执行原理:

 

当两个变量指向同一个对象时,前一个过来修改,后一个再过来时可以看到修改后的对象

如果某个数组变量存储的地址是null,那么该变量将不会再指向任何数组对象。 

 

5、数组案例 

5.1数组求最值

案例:数组元素求最大值

实现步骤:

  • 把颜值数据拿到程序中去,用数组装起来
  • 定义一个变量用于记录最终的的最大值  max  建议存储数组的第一个元素作为参照
  • 从第二个位置开始:遍历数组的数据,如果遍历的当前数据大于max变量存储的数据,则替换变量存储的数据为当前数据。
  • 循环结束后输出max变量即可
package com.demo;

public class Test1 {
    public static void main(String[] args) {
        //1、
        int[] faceScores={15,9000,10000,20000,9500,-5};
        //2、
        int max=faceScores[0];
        //3、
        for (int i = 1; i < faceScores.length; i++) {
            //i=1 2 3 4 5
            if(faceScores[i]>max)
            {
                max=faceScores[i];
            }
        }
        System.out.println("最高颜值是:" + max);
    }
}

结果:

5.2数组反转

需求:

  • 某个数组有5个数据:10,20,30,40,50,请将这个数组中的数据进行反转

[ 10  20  30  40  50 ] 反转后 [ 50  40  30  20  10 ]

分析:

  • 数组的反转操作实际上就是:依次前后交换数据即可实现

 具体操作类似 http://t.csdnimg.cn/UYm7l

里面的字符串逆序

package com.demo;

public class Test2 {
    public static void main(String[] args) {
        //1、准备数组
        int[] arr ={10,20,30,40,50};
        //           i           j
        //2、定义两个变量,一个在前,一个在后
        for (int i = 0,j=arr.length-1; i < j; i++,j--) {
            //arr[i]  arr[j]
            //交换
            //1、定义一个临时变量记住最后一个位置处的值
            int temp=arr[j];
            //2、把前一个位置处的值给后一个位置
            arr[j]=arr[i];
            //3、把临时变量中记住的最后一个位置处的值赋值给前一个位置处
            arr[i]=temp;

        }
        //3、遍历数组中的每个数据,看是否反转成功了
        for (int i = 0; i < arr.length; i++) {
            System.out.print(arr[i] + " ");
        }
    }
}

结果:

5.3随机排名

需求:

  • 某公司开发部5名开发人员,要进行项目进展汇报演讲,现在采取随机排名后进行汇报。请依次录入5名员工的工号,然后展示处一组随机的排名顺序。

分析

1、录入5名员工工号存储---> 使用动态初始化数组

2、依次遍历数组中的每个数据

3、每遍历到一个数据,都随机一个索引值出来,让当前数据与该索引位置处的数据进行交换

4、遍历数组中的工号输出

package com.demo;

import java.util.Random;
import java.util.Scanner;

public class Test3 {
    public static void main(String[] args) {
        //1、
        int[] codes=new int[5];
        //[0 0 0 0 0]
        // 0 1 2 3 4
        //2、
        Scanner sc=new Scanner(System.in);
        for (int i = 0; i < codes.length; i++) {
            //i= 0 1 2 3 4
            System.out.println("请输入当前第" + (i + 1) + "个员工的工号");
           int code=sc.nextInt();
           codes[i]=code;
        }
        //3、打乱数组中元素的顺序
        //每遍历到一个数据,都随机一个数组索引范围内的值,然后让当前遍历的数据与该索引位置处的值交换
        Random r=new Random();
        for (int i = 0; i < codes.length; i++) {
            int index=r.nextInt(5);//0-4
            int temp=codes[index];
            codes[index]=codes[i];
            codes[i]=temp;
        }
        //4、
        for (int i = 0; i < codes.length; i++) {
            System.out.print(codes[i] + " ");
        }
    }
}

 结果:

补充知识:Debug工具的使用

Debug工具

  • IDEA自带的断点调试工具,可以控制代码从断点开始一行一行的执行,然后详细看程序执行情况

Debug工具基本使用步骤: 

 

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

【SPSS】基于因子分析法对水果茶调查问卷进行分析

&#x1f935;‍♂️ 个人主页&#xff1a;艾派森的个人主页 ✍&#x1f3fb;作者简介&#xff1a;Python学习者 &#x1f40b; 希望大家多多支持&#xff0c;我们一起进步&#xff01;&#x1f604; 如果文章对你有帮助的话&#xff0c; 欢迎评论 &#x1f4ac;点赞&#x1f4…

【Python】解决Python报错:TypeError: can only concatenate str (not “int“) to str

&#x1f9d1; 博主简介&#xff1a;阿里巴巴嵌入式技术专家&#xff0c;深耕嵌入式人工智能领域&#xff0c;具备多年的嵌入式硬件产品研发管理经验。 &#x1f4d2; 博客介绍&#xff1a;分享嵌入式开发领域的相关知识、经验、思考和感悟&#xff0c;欢迎关注。提供嵌入式方向…

P2341 受欢迎的牛

题目描述 每一头牛的愿望就是变成一头最受欢迎的牛。现在有 N 头牛&#xff0c;给你 M 对整数&#xff0c;表示牛 A 认为牛 B 受欢迎。这种关系是具有传递性的&#xff0c;如果 A 认为 B 受欢迎&#xff0c;B 认为 C 受欢迎&#xff0c;那么牛 A 也认为牛 C 受欢迎。你的任务是…

058.最后一个单词的长度

题意 给你一个字符串 s&#xff0c;由若干单词组成&#xff0c;单词前后用一些空格字符隔开。返回字符串中 最后一个 单词的长度。 单词 是指仅由字母组成、不包含任何空格字符的最大子字符串。 难度 简单 示例 1&#xff1a; 输入&#xff1a;s "Hello World" 输…

开抖店必须要办理营业执照吗?不用营业执照开店的个人店能用吗?

大家好&#xff0c;我是电商花花。 可能大家都发现了&#xff0c;抖音小店个人店不用营业执照&#xff0c;只凭借身份证就能开店。 但是这个个人店花花并不建议大家去开&#xff0c;虽然说用用身份证也能开店&#xff0c;有效的帮我们减少了开店的成本&#xff0c;但是个人店…

2024 angstromCTF re 部分wp

Guess the Flag 附件拖入ida 比较简单&#xff0c;就一个异或 switcher 附件拖入ida 明文flag Polyomino 附件拖入ida 需要输入九个数&#xff0c;然后进入处理和判断&#xff0c;如果满足条件则进入输出flag部分&#xff0c;flag和输入有关&#xff0c;所以要理解需要满足什么…

Ai速递5.29

全球AI新闻速递 1.摩尔线程与无问芯穹合作&#xff0c;实现国产 GPU 端到端 AI 大模型实训。 2.宝马工厂&#xff1a;机器狗上岗&#xff0c;可“嗅探”故障隐患。 3.ChatGPT&#xff1a;macOS 开始公测。 4.Stability AI&#xff1a;推出Stable Assistant&#xff0c;可用S…

GPT-4o:人工智能新纪元的开端

引言 近年来&#xff0c;人工智能领域的发展日新月异&#xff0c;特别是在自然语言处理&#xff08;NLP&#xff09;领域&#xff0c;各种生成预训练模型不断推陈出新。自OpenAI发布GPT-3以来&#xff0c;生成预训练模型在文本生成、语言理解等任务中展现了强大的能力。近期&a…

MVC和MVVM

MVC Model层&#xff1a;用于处理应用程序数据逻辑的部分&#xff0c;通常负责在数据库中存取数据 View&#xff08;视图&#xff09;处理数据显示的部分。通常视图是依据模型数据创建的 Controller&#xff08;控制器&#xff09;是处理用户交互的部分。通常控制器负责从视…

Orange Pi Kunpeng Pro测评

#创作灵感# 参加树莓派鲲鹏开发版的测评活动&#xff0c;也想体验一下该开发版&#xff0c;之前有做过树莓派和香橙派的开发&#xff0c;刚好借此机会了解一下鲲鹏&#xff0c;所以就有了这篇测评文章。 #正文# 引言 说是测评&#xff0c;其实也没有多少测评方面的内容&…

基于jeecgboot-vue3的Flowable新建流程定义(二)

因为这个项目license问题无法开源&#xff0c;更多技术支持与服务请加入我的知识星球。 接上一节 4、编辑好后进行保存&#xff0c;保存代码如下&#xff1a; /*保存流程定义*/const save (data: any) > {//console.log("save data", data); // { process: {..…

装机必备——截图工具Snipaste安装教程

装机必备——截图工具Snipaste安装教程 软件下载 软件名称&#xff1a;Snipaste2.7 软件语言&#xff1a;简体中文 软件大小&#xff1a;15.37M 系统要求&#xff1a;Windows7或更高&#xff0c; 32/64位操作系统 硬件要求&#xff1a;CPU2GHz &#xff0c;RAM2G或更高 下载通…

RAG 高级应用:基于 Nougat、HTML 转换与 GPT-4o 解析复杂 PDF 内嵌表格

一、前言 RAG&#xff08;检索增强生成&#xff09;应用最具挑战性的方面之一是如何处理复杂文档的内容&#xff0c;例如 PDF 文档中的图像和表格&#xff0c;因为这些内容不像传统文本那样容易解析和检索。前面我们有介绍过如何使用 LlamaIndex 提供的 LlamaParse 技术解析复…

重学java51.Collections集合工具类、泛型

"我已不在地坛&#xff0c;地坛在我" —— 《想念地坛》 24.5.28 一、Collections集合工具类 1.概述:集合工具类 2.特点: a.构造私有 b.方法都是静态的 3.使用:类名直接调用 4.方法: static <T> boolean addAll(collection<? super T>c,T... el…

精通推荐算法6:用户行为序列建模 -- 总体架构

1 行为序列建模技术架构 身处目前这个信息爆炸的时代&#xff0c;用户在各推荐场景上有丰富的行为序列。将行为序列特征引入推荐算法中&#xff0c;有利于丰富特征工程体系、获得更立体和更全面的信息&#xff0c;同时可以表达用户兴趣演化过程&#xff0c;并捕获用户实时兴趣…

信号处理中简单实用的方法

最小二乘法拟合消除趋势项 消除趋势项函数 在MATLAB的工具箱中已有消除线性趋势项的detrend函数&#xff1b;再介绍以最小二乘法拟合消除趋势项的polydetrend 函数。 函数:detrend功能:消除线性趋势项 调用格式:ydetrend(x) 说明:输入参数x是带有线性趋势项的信号序列,输出…

OrangePi Kunpeng Pro 开发板测评 | AI 边缘计算 大模型部署

0 前言 此次很幸运能够参与 OrangePi Kunpeng Pro 开发板的测评&#xff0c;感谢 CSDN 给予这次机会。 香橙派联合华为发布了基于昇腾的 OrangePi Kunpeng Pro 开发板&#xff0c;具备 8TOPS 的 AI 算力&#xff0c;能覆盖生态开发板者的主流应用场景&#xff0c;具备完善的配…

这些项目,我当初但凡参与一个,现在也不至于还是个程序员

10年前&#xff0c;我刚开始干开发不久&#xff0c;我觉得这真是一个有前景的职业&#xff0c;我觉得我的未来会无限广阔&#xff0c;我觉得再过几年&#xff0c;我一定工资不菲。于是我开始像很多大佬说的那样&#xff0c;开始制定职业规划&#xff0c;并且坚决执行。但过去这…

使用C语言openssl库实现 RSA加密 和 消息验证

Q&#xff1a;什么是RSA&#xff1f; A&#xff1a;RSA&#xff08;Rivest-Shamir-Adleman&#xff09;是一种非对称加密算法&#xff0c;是最早的一种用于公开密钥加密和数字签名的算法。它使用一对公钥&#xff08;public key&#xff09;和私钥&#xff08;private key&…

小阿轩yx-Shell编程之正则表达式与文本处理器

小阿轩yx-Shell编程之正则表达式与文本处理器 正则表达式 &#xff08;RegularExpression&#xff0c;RE&#xff09; 正则表达式概述 正则表达式的定义 又称 正规表达式常规表达式 代码中常简写为 regex、regexp 或 RE 正则表达式 使用单个字符串来描述、匹配一系列符…