第二周笔记

news2024/11/24 14:27:49

public class Calc {
    //加法, 把和作为一个结果返回出去, 返回给调用者
    public int add3(int num1, int num2){
        if(num1 == 0 && num2 == 0){
            return 0;  //隐式包含一个if-else结构
        }
        //使用return 关键字
        return num1 + num2;
    }

    public void fun1(){
        System.out.println("开始执行fun1方法...");
        if(true){
            System.out.println("fun1方法中途退出");
            return;  //退出方法
        }
        System.out.println("fun1方法执行完成");
    }

    public void fun2(){
        for (int i = 0; i <10 ; i++) {
            System.out.println(i);
            if(i == 5){
               // break; //退出循环 0~5  fun2执行完成
                return; //退出方法 0~5
            }
        }
        System.out.println("fun2执行完成....");
    }

    public static void main(String[] args) {
        Calc calc = new Calc();
        /*
        //调用有返回值的方法
        calc.add3(10,8);//程序能正常运行, 但是返回值结果数据丢失
        int rs = calc.add3(11,8);
        System.out.println(rs);
        long rs1 = calc.add3(11,8); // int 自动转换为long
        System.out.println(rs1);
         */
        //调用fun1
        calc.fun1();

        calc.fun2();


        int[] arr = {1,2,55,22,33,111,222,56};
        int[] rsArr = calc.findMaxAndMin(arr);
        System.out.println("最大值:"+rsArr[0]);
        System.out.println("最小值:"+rsArr[1]);
    }


    //如果一个方法返回多个数据   找数组的最大值,最小值并返回
    //返回数组
    // 返回值类型可以是数组类型
    public  int[] findMaxAndMin(int[] arr){
        int[] nums = new int[2]; //存放最大值,最小值
        int max = arr[0];
        int min = arr[0];
        for (int i = 1; i < arr.length; i++) {
            //找最大值
            if(max < arr[i]){
               max = arr[i];
            }
            //最小值
            if(min > arr[i]){
                min = arr[i];
            }
        }

        //把最大值,最小值保存数组
        nums[0] = max;
        nums[1] = min;
        return nums;
    }

    public int fun3(int a){
        if(true){
            return 1;
        }
        return -1;
    }
}
 

 

 

带参方法

方法定义的参数称为形参, jdk判断方法参数列表: 根据参数数据类型, 参数个数, 参数的位置

调用方法的时候, 传递变量, 称为实参

方法的参数传递: 值传递

对于基本数据类型的参数,形式参数的改变,不影响实际参数的值 值数据

对于引用数据类型(类类型)的参数, 形式参数的改变,影响实际参数的值 地址码

有返回值的方法

定义有返回值方法, 在方法体使用return 结果返回数据.

有返回值方法的调用: 需要定义变量接收方法返回值, 保存数据

接收返回值的变量的数据类型与返回值类型匹配

return 使用方式:

  • return 退出方法 只能在无返回值的方法内部使用

  • return 结果 只能在有返回值的方法内部使用, 1) 返回结果 2) 退出方法

return关键字作用: 退出方法

方法重载

如果一组方法, 功能类似的, 但是参数不一样,

第一种方式: 给每个方法取不同的名字, 通过名字来区分

缺点:

  1. 开发者想一堆的名字

  2. 使用者记一堆的名字

第二种方式: JAVA提供了 方法重载的机制

在同一个类中, 方法名一样, 参数列表不一样的一组方法,称为方法的重载, 与返回值无关

参数列表不一样:

  1. 参数个数不一样

  2. 参数对应位置的数据类型不一样

  3. 与参数名无关

功能相似的推荐使用方法重载的方式, 如果不同功能的方法, 取不同的方法名

方法注意事项

  • 方法内部不能再定义方法

  •  

 

 

 

 

 

 

//1,声明一个二维数组
        int[][] arr;
        //2. 开辟空间
        arr = new int[3][4];  // 包含3个一维数组,而且每一个一维数组长度都是4
        //第一个长度: 3: 一维数组的个数
        //第二个长度: 4: 一维数组的长度
        //arr[下标]: 获取下标为几的一维数组
        arr[0] = new int[]{1,2,3,4,5};
        arr[1] = new int[]{1,3,5,7};
        arr[2] = new int[]{2,4,6,8};
        //arr[3] = new int[]{2,4,6,8};

        int[][] arr2 = new int[5][];
        // arr2二维数组包含5个一维数组, 但是每一个一维数组的长度不确定

        //循环变量
        // 得到一维数组的个数: 数组名.length
        for (int i = 0; i <arr.length ; i++) { //控制一维数组
            // 每一个一维数组的长度 arr[i].length
            for (int j = 0; j < arr[i].length; j++) { //遍历每一个一维数组
                //arr[0][0]: 二维数组中第一个一维数组的第一个元素
                System.out.print(arr[i][j]+", ");
            }
            System.out.println();
        }

//冒泡排序
        int arr[] = {26,34,1,29,39,28,2,44,48,27,12};

        //升序排序
        for (int i = 1; i <= arr.length -1 ; i++) {  //控制的轮  = 数组的长度-1
            for (int j = 0; j < arr.length -i; j++) { //每一轮的次数  j作为数组下标  = 数组长度 - 轮
                //两两比较,如果违反规则,进行交换
                //if(arr[j] > arr[j+1]){ //如果前一个元素比后一个元素大,违反规则 升序
                if(arr[j] < arr[j+1]){   //降序 大在前,小在后  违反规则(大的在后)
                    //交换
                    int temp = arr[j];
                    arr[j] = arr[j+1];
                    arr[j+1] = temp;
                }
            }
        }

        System.out.println("排序之后的结果:");
        for (int i = 0; i < arr.length; i++) {
            System.out.print(arr[i]+", ");
        }

 

## 二维数组

一维数组:   `数组名[]`

二维数组: `数组名[][]`   由多个一维数组组成

三维数组: `数组名[][][]`  由多个二维数组组成

 

二维数组的第一个长度,设不设意义不大

二维数组名.length: 表示二维数组包含多少个一维数组

二维数组名[i].length: 表示获取二维数组中下标为i的一维数组的长度

获取每一个元素: 数组名[i][j]

实际开发中: 常用的一维数组, 多维数组: 使用一维对象数组来表示

java: 面向对象编程

数组的排序, 面试

升序,降序

十大排序方式: 冒泡, 选择, 插入, 堆排序….

冒泡排序

数据结构和算法动态可视化 (Chinese) - VisuAlgo

思路:

1. 从数组的第一个元素开始,依次与后面的元素进行两两比较, 如果违反排序规则,进行交换, 经过第一轮, 把最大/最小的元素排在最后一个位置

  1. 从数组的第一个元素开始,依次与后面的元素进行两两比较, 如果违反排序规则,进行交换, 经过第二轮, 把第二大/第二小的元素排在倒数第二个位置

  2. 依次内推, 把第二小/第二大的元素排在第二个位置, 该数组排序完成

数组有10个元素: 确定9个

排序轮数 = 数组长度-1 : 外循环

每一轮比较的次数: = 数组长度 - 轮数 : 内循环

排序性能: 时间复杂度 O(n^2) 循环的次数

最小的时间复杂度: O(n)

扩展: 选择排序, 插入排序, 每一种排序时间复杂度

 

int left = 0;

int right = arr.length - 1;

while(left < right){

        int min = left;

        int max = left;

        for(int i = left;i <= right;i++){

                if(arr[i] < arr[min]){

                        min = i;

                }

                if(arr[i] > arr[max]){

                        max= i;

                }

        }

        swap(arr[left],arr[min]);

        if(left == max){

                max = min;

        }

        swap(right,max);

        left++;

        right--;

}

选择排序:O(n^2) 因为每一次遍历数组数组时,都要遍历数组选出最大和最小的数组,每一次遍历都是O(n),就算是自身有序的也要遍历筛选

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

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

相关文章

【Linux操作系统】多线程抢票逻辑——学习互斥量(锁)函数接口

文章目录 1.进程线程间的互斥相关背景概念2.联系代码学习同步互斥问题3.互斥量&#xff08;锁&#xff09;的函数接口3.1初始化互斥量3.2销毁互斥量3.3互斥量加锁和解锁3.4改进多线程抢票代码 1.进程线程间的互斥相关背景概念 临界资源&#xff1a;多线程执行流共享的资源就叫…

beego验证码(配置到redis存储)

我们定义一个全局变量用于存储redis连接 RedisDb *redis.Client 然后连接 redis 这一块我们将redis信息写到app.conf文件里了&#xff1a; redisDb 1 redisAddr "127.0.0.1:6379" redisPwd "" package initializeimport ("beego_learning/global&q…

【Java基础教程】(十四)面向对象篇 · 第八讲:多态性详解——向上及向下转型、关键字 final与 instanceof的作用~

Java基础教程之面向对象 第八讲 本节学习目标1️⃣ final 关键字1.1 final类1.2 final方法1.3 final属性 2️⃣ 多态性2.1 向上转型2.2 向下转型2.3 关键字 instanceof &#x1f33e; 总结 本节学习目标 掌握final 关键字的主要作用及使用&#xff1b;掌握对象多态性的概念以…

【CSDN新星计划】初阶牛C/C++赛道——顺序程序设计(C语句)

目录 3.1 C语句的作用和分类 &#x1f349;&#xff08;1&#xff09;控制语句 &#x1f349;&#xff08;2&#xff09;函数调用语句 &#x1f349;&#xff08;3&#xff09;表达式语句 &#x1f349;&#xff08;4&#xff09;空语句 &#x1f349;&#xff08;5&#…

【C++进阶之路】vector的基本使用和模拟实现

前言 作为STL的容器之一&#xff0c;vector的名字通常令人疑惑&#xff1f;在字面上&#xff0c;我们通常会翻译成向量&#xff0c;但感觉又解释不通&#xff0c;总觉得应该叫dynamic array翻译成动态数组/顺序表&#xff0c;更容易理解&#xff1f;那为啥呢&#xff1f; 我从…

【Java】微服务项目的部署

微服务项目的部署 准备Centos安装 Docker镜像加速检查加速器是否生效 下载docker-compose方法1 curl方法2 pip方法3 直接下载released 用docker-compose部署中间件导入项目安装jdk maven git设置idea内存减小jar启动占用内存增加idea可使用内存 本文参考 https://gitee.com/…

音乐怎么转换成wav格式?分享这五个方法给大家!

在音频编辑和处理过程中&#xff0c;将音乐文件转换为WAV格式是一种常见需求。WAV格式以其无损音质和广泛的兼容性而受到许多人的喜爱。下面介绍了五种常用的方法&#xff0c;帮助您将音乐文件转换为WAV格式&#xff0c;其中方法一使用记灵在线工具。 方法一&#xff1a;记灵在…

非常规自增自减

非常规自增自减 目录 一&#xff0e; 概述二&#xff0e; 例题 一&#xff0e; 概述 在C语言的单目操作符中有&#xff08;自增&#xff09;和–&#xff08;自减&#xff09;这两个运算符。假设有变量i&#xff0c;我想让变量i加上1&#xff0c;那么我们会写成ii1这样的形式。…

自旋锁与开关中断临界区的区别

自旋锁和开关中断临界区都是用于保护共享资源的机制&#xff0c;但它们的实现方式和使用场景有所不同。 自旋锁主要是用于多核CPU上的并发编程中&#xff0c;它通过不断地检查锁的状态来等待锁的释放&#xff0c;从而避免了线程的阻塞。当一个线程需要访问共享资源时&#xff…

VTK 三维模型 体绘制 关于环境光、漫反射、镜面反射

光源: 1):环境光:环境光是一种低强度的光,由光线经过周围环境表面多次反射后形成的,利用环境光可以描述一块区域的亮度,通常在场 景中,环境光的颜色是一个常量. 2):太阳光:即定向光源,特点是从无穷远出发射光线,光线是平行的,光线强度不会随着距离衰减. 3):点光源:在有限空间…

maven安装和换源

1. 安装(17条消息) maven历史版本下载和安装_beiback的博客-CSDN博客 安装 maven历史版本仓库 下载 Index of /dist/maven/maven-3 (apache.org)https://archive.apache.org/dist/maven/maven-3/ 选择对应版本-binaries/-zip 解压即可使用 2.换源 (17条消息) 手把手教你更改…

【读书笔记】从实模式到保护模式

计算机语言 x86汇编语言&#xff1a;从实模式到保护模式&#xff08;操作系统引导课&#xff09; 原书作者李忠 用电表示数据 寄存器的作用&#xff1a;具有记忆功能的器件。锁存可以通过下面的开关控制&#xff0c;平时开关为空&#xff0c;按下开关之后&#xff0c;将输入锁…

PLEX如何搭建个人局域网的视频网站

Plex是一款功能非常强大的影音媒体管理系统&#xff0c;最大的优势是多平台支持和界面优美&#xff0c;几乎可以在所有的平台上安装plex服务器和客户端&#xff0c;让你可以随时随地享受存储在家中的电影、照片、音乐&#xff0c;并且可以实现观看记录无缝衔接&#xff0c;手机…

VScode——NPM脚本窗口找不到

一、问题描述&#xff08;NPM终端在任务栏左侧找不到&#xff09; VScode&#xff08;Visual Studio Code&#xff09;版本&#xff1a;1.79.2 二、解决办法 第一步&#xff1a;通过设置/用户设置/扩展/MPM更改NPM默认配置&#xff0c;如下图所示&#xff1a; 第二步&#xff…

[java安全]CommonsCollections6

文章目录 【java安全】CommonsCollections6**测试环境**前言分析TiedMapEntry注意点一注意点二POC调用栈 【java安全】CommonsCollections6 测试环境 3.1-3.2.1&#xff0c;jdk1.7,1.8 前言 之前我们分析了CommonsCollections1 LazyMap利用链&#xff0c;但是在java 8u71以…

2023 年中回顾:珍惜当下,锻炼身体

文章大纲 过去几十年的经验&#xff1a;人类的悲喜并不相同马太效应破圈&#xff1a;健康的身体写博客这件事&#xff1a;价值导向参考文献 距离上次阶段性回顾仅仅过去半年&#xff0c;感觉整个IT 行业天翻地覆慨而慷了。 时光荏苒&#xff0c;我自己也在芯片领域深耕了365天&…

swagger不可用

swagger不可用 问题描述问题处理测试环境外网域名测试环境内网域名思考 总结 问题描述 上周swagger还没啥问题&#xff0c;这周一测试突然和我说&#xff0c;测试环境的swagger都用不了了&#xff0c;然后开始找原因 问题处理 测试环境外网域名 一直跳这个弹窗&#xff0c;百度…

学习AJAX

AJAX &#x1f680; HTTP请求报文响应报文 &#x1f684; express框架&#x1f6ac; express基本使用 &#x1f692; 原生AJAX&#x1f6ac; GET.HTML&#x1f6ac; POST.HTML&#x1f6ac; JSON.HTML&#x1f6ac; nodemon工具可以帮助重启服务&#x1f6ac; IE缓存问题&#…

MIT 6.829 -- L0 Background: Single-Link Communication

MIT 6.829 -- L0 Background: Single-Link Communication 前言ProblemModulation(调制) & Demodulation(解调)FramingError DetectionError RecoveryARQ Shared Media Access总结 本课程为MIT 6.829 计网课程,课程对应官网链接: Computer Networks Lecture Notes 本节对应…

操作系统——虚拟内存管理

文章目录 一、虚拟内存中的几种地址1、逻辑地址2、线性地址3、逻辑地址转线性地址4、线性地址转物理地址 二、进程与内存1、内核空间和用户空间2、内存映射3、进程内存分配与回收 早期程序直接运行在物理内存上&#xff0c;直接操作物理内存&#xff0c;这种方式存在几个问题&a…