WGL的Day05

Java方法

  • System.out.println() : System是一个类,out是对象,println()是一个方法,

​ 调用系统类System中的out对象中的println()方法

  • Java方法是语句的集合 , 它们在一起执行一个功能
    • 方法是解决一类问题的步骤的有序组合
    • 方法包含与类或对象中
    • 方法在程序中被创建 , 在其他地方被引用
  • 设计方法的原则 : 方法的本意是功能块,就是实现某个功能的语句块的集合.

​ 我们设计方法的时候,最好保持方法的原子性,**就是一个方法只完成一个功能

​ 这样利于我们后期的扩展.

方法的定义

修饰符 返回值类型 方法名(参数类型 参数名){
    ...
        方法体
      
        return 返回值;
}

◆Java的方法类似于其它语言的函数,是一段用来完成特定功能的代码片段, 一般情况下,定义一个方法包含以下语法:

◆方法包含-一个方法头和一个方法体。下面是一个方法的所有部分:

◆修饰符:修饰符,这是可选的,告诉编译器如何调用该方法。定义了该方法的访问类型。

返回值类型:方法可能会返回值。returnValueType 是方法返回值的数据类型。有些方法执行所需的操作,但没有返回值。在这种情况下,returnValueType 是关键字void.

◆方法名: 是方法的实际名称。方法名和参数表共同构成方法签名。

◆参数类型:参数像是一个占位符。当方法被调用时,传递值给参数。这个值被称为实参或变量。参数列表是指方法的参数类型、顺序和参数的个数。参数是可选的,方法可以不包含任何参数

  • 形式参数 : 在方法被调用时用于接收外界输入的数据
  • 实参 : 调用方法时实际传给方法的数据

◆方法体 : 方法体包含具体的语句,定义该方法的功能

输入两数比较大小

package JavaSE;

import java.util.Scanner;

public class day05_2 {
    public static void main(String[] args) {
        System.out.print("请输入第一个数字:");
        Scanner a1 = new Scanner(System.in);
        int a= a1.nextInt();
        System.out.print("请输入第二个数字:");
        int b = a1.nextInt();
        int max = max(a,b);
        System.out.println("最大的数是:"+max);

    }
    public static void f(){
        System.out.println("两个数相等");
    }                                      //无返回值的方法f
    public static int max(int a,int b) {
        int result=0;
        if (a > b) {
            result = a;
        } else if (a == b) {
            f();                          //直接调用f();

        }
        else{
            result=b;
        }
      return result;
    }                                      //有返回值的方法max
}

方法的重载

package JavaSE;

import java.util.Scanner;

public class day05_2 {
    public static void main(String[] args) { 
        int max = max(10,20);     // double max = max(10.5,20.7);
        System.out.println("最大的数是:"+max);

    }
    public static void f(){
        System.out.println("两个数相等");
    }     //无返回值的方法f
    
    
    
    //int类型
    public static int max(int a,int b) {
        int result=0;
        if (a > b) {
            result = a;
        } else if (a == b) {
            f();                          //直接调用f();

        }
        else{
            result=b;
        }
      return result;
    }  
    
    
    
    //重载到double类型
    public static double max(double a,double b) {
        double result=0;
        if (a > b) {
            result = a;
        } else if (a == b) {
            f();                          //直接调用f();

        }
        else{
            result=b;
        }
      return result;//有返回值的方法max
     }
}

命令行传参

package JavaSE;

public class day05_4 {
    public static void main(String[] args) {
        //args.length数组长度
        for (int i = 0;i<args.length;i++){
            System.out.println("args["+i+"]:"+args[i]);
        }
    }
}
//用命令行给main中的args[]传递参数

编译时直接打开cmd时用javac 文件.java

然后退回到src文件下,java 文件夹.文件名,会发现没有任何参数输出

复制以上内容,java 文件夹.文件名 + 需要添加的参数

在这里插入图片描述

可变参数

package JavaSE;

public class day05_5 {
    public static void main(String[] args) {
        day05_5 a1 = new day05_5();
        a1.test(12,3,67,74,1,8);                //a1.text(x:12,...i:3,67,74,1,8);
    }
    public void test(int x,int...i){ //int...i只能放在最后
        System.out.println(i[0]);
        System.out.println(i[1]);
        System.out.println(i[2]);
        System.out.println(i[3]);
        System.out.println(i[4]);
    }
}

递归

自己调用自己

package JavaSE;

import java.util.Scanner;

public class day05_6 {
    public static void main(String[] args) {
        Scanner a1 = new Scanner(System.in);
        int n= a1.nextInt();
        int sum = f(n);
        System.out.println(sum);

    }
    public static int f(int n){
        if (n==1){
            return 1;
        }
        else{
            return n*f(n-1); //5*f(4),f(4)=4*f(3)...5*4*3*2*1
                             //调用自己,达到循环
        }
    }

}

数组

  • 数组是相同类型数据的集合
  • 数组描述的是相同类型的若干个数据,按照一定的先后次序排列组合而成
  • 其中,每一个数据称作一个数组元素,每个数组元素可以通过一个下标来访问它们

数组的创建

  • 首先必须声明数组的变量,才能在程序中使用数组,下面是声明数组变量的语法:
dataType[] arrayRefvar;        //首先格式
dataType arrayRefvar[];        //效果相同,不建议使用
  • Java语言使用new操作符来创建数组,语法如下:
//dataType[] arrayRefvar = new dataType[arraySize]


package JavaSE;

public class day05_7 {
    public static void main(String[] args) {
        //数组的类型 数组名字 = 数组的值
            int [] nums;    //声明一个int类型的数组nums
        nums = new int[10]; //创建一个数组,可存放10个int类型的数
        nums[0] = 1;
        nums[1] = 2;
        nums[2] = 3;
        nums[3] = 4;
        nums[4] = 5;
        nums[5] = 6;
        nums[6] = 7;
        nums[7] = 8;
        nums[8] = 9;
        nums[9] = 10;       //赋值
    }
}

在这里插入图片描述

数组第一位数的标签为0(nums[0])

  • 获取数组长度

    数组名.lenght

内存分析

Java内存

在这里插入图片描述

内存中

在这里插入图片描述

三种初始化

  • 静态初始化
int[] a = {1,2,3};
Man[] mans = {new Man(1,1),new Man(2,2)};

  • 动态初始化
int[] a = new int[2];
a[0]=1;
a[1]=2;
  • 数组的默认初始化

    • 数组是引用类型,它的元素相当于类的实例变量,因此数组一经分配空间,

      其中每个元素也被按照实例变量同样的方式被隐式初始化

package JavaSE;

public class day05_8 {
    public static void main(String[] args) {
        //静态初始化:创建 + 赋值
        int[] a = {1,2,3,4,5,6,7,8};
        System.out.println(a[0]);

        //动态初始化:创建空间后赋值
        int [] b = new int[10];
        b[0] = 10;
        System.out.println(b[0]);

        //默认类型:int为0,String为null
        System.out.println(b[1]);  //输出为0
    }
}

数组的四个基本特点

  • 其长度必须是确定文的,数据一旦被创建,它的大小就是不可以改变的
  • 其元素必须是相同类型,不允许出现混合类型
  • 数组中的元素可以是任何数据类型,包括基本类型和引用类型
  • 数组变量属于引用类型,数组也可以看成是对象,数组中的每个元素相当于该对象的成员变量,数组本身就是对象,Java中对象是在堆中的,因此数组无论保存原始类型还是其他对象类型,数组对象本身是在堆中的. new出来的元素都是在堆中的

数组边界

  • 下标的合法区间 : [0,length-1],如果越界就会报错;
public static void main(String[]args){
    int[] a= new int[2];
    System.out.println(a[2]);  //越界!,最后一位为a[1]
}

◆小结:

◆数组是相同数据类型(数据类型可以为任意类型)的有序集合

◆数组也是对象。数组元素相当于对象的成员变量

◆数组长度的确定的,不可变的。如果越界,则报: ArrayIndexOutofBounds

数组的使用

package JavaSE;

public class day05_9 {
    public static void main(String[] args) {
        int []arrays = {1,2,3,4,5};
        for (int i = 0;i<arrays.length;i++) {
            System.out.println(arrays[i]);

        }
        //求和
        System.out.println("------------------");
        int num = 0;
        for (int i =0;i<arrays.length;i++){
            num = num + arrays[i];

        }
        System.out.println("和位:"+num);
        //求最大数
        int m=arrays[0];
        for (int i = 0;i<arrays.length;i++){
            if (arrays[i]>m){
                m=arrays[i];
            }
        }
        System.out.println("最大值为:"+m);
    }
}

打印数组元素

package JavaSE;

public class day05_10 {
    public static void main(String[] args) {
        int[] array = {1,2,3,4,5,6};
        printArray(array);
    }

    public static void printArray(int[] array) {
        for (int i =0;i<array.length;i++){
            System.out.print(array[i]+" ");
        }
    }
}

反转数组

package JavaSE;

public class day05_10 {
    public static void main(String[] args) {
        int[] array = {1,2,3,4,5,6};
        printArray(array);
        int[] reverse = reverse(array);
        printArray(reverse);
    }

    public static void printArray(int[] array) {
        for (int i =0;i<array.length;i++){
            System.out.print(array[i]+" ");
        }

    }

    //反转操作
    public static int[] reverse(int[]array) {
        int[] result = new int[array.length];

          //反转
        for (int i = 0,j=result.length-1;i<array.length;i++,j--){
            result[i]=array[j];
        }

       return result;

    }
}

二维数组

int [ ] [ ] a = {{1,2},{3,4},{5,6}};

a[0] = {1,2};

Arrays类

package JavaSE;

import java.util.Arrays;

public class day05_11 {
    public static void main(String[] args) {
        int a [] = {556,4677,7,89,1,763};
        System.out.println(a);        //[I@1b6d3586
        System.out.println(Arrays.toString(a));//Arrays类的功能语句,输出带[]的数组
        printArray(a);
        System.out.println();
        Arrays.sort(a);                //Arrays.sort从小到大排序
        System.out.println(Arrays.toString(a));
        Arrays.fill(a,2,4,0) ;       //Arrays.fill,第二到第四元素被0覆盖
        System.out.println(Arrays.toString(a));

    }
    public static void printArray(int[] a){     //自建printArray方法和toString效果相同
        for (int i = 0;i<a.length;i++){
            if(i==0){
                System.out.print("["+a[i]+","+" ");

            }
            else if (i==a.length-1){
                System.out.print(a[i]+"]");
            }else{
            System.out.print(a[i]+","+" ");}
        }
    }
    
}

冒泡排序

比较数组中两个相邻的元素,找打一个最大(小)并排序,每一轮少一个数

在这里插入图片描述

在这里插入图片描述

在这里插入图片描述

在这里插入图片描述

package JavaSE;

import com.sun.xml.internal.ws.api.model.wsdl.WSDLOutput;

import java.util.Arrays;

public class day05_12 {
    public static void main(String[] args) {


        int[] a = {15, 85, 9, 4447, 513, 1}; //定义一个数组a
        sort(a);            //int [] a1 = sort(a);
        System.out.println(Arrays.toString(a));
    }
        //冒泡排序,比较数组中两个相邻的元素,找打一个最大(小)并排序,每一轮少一个数
    public static int[] sort(int[] array) {
        //临时变量
        int temp = 0;
        //外循环,判断我们这个要走多少次
        for (int i = 0;i<array.length;i++ ){
            //内层循环,依次比较两个数的大小,并交换位置
            for (int j = 0;j<array.length-1;j++){
                if (array[j]<array[j+1]){
                    temp = array[j+1] ;
                    array[j+1] = array[j];
                    array[j] = temp;

                }
            }
        }
      return array;
    }
}

稀疏数组

  • 需求:编写五子棋游戏中,有存盘和续上盘的功能

在这里插入图片描述

  • 问题:因为该二维数组中有很多值是默认为0的,因此记录了很多没有意义的数据

  • 解决:稀疏数组

在这里插入图片描述

[0]代表这个二维数组是6行7列有8个有效值

[1]…代表8个有效数字的位置和具体值

package JavaSE;

public class day05_13 {
    public static void main(String[] args) {
        //创建一个二维数组 11*11 0:没有棋子 1:黑棋 2:白棋
        int[][] array1 = new int[11][11];
        array1[1][2]=1;
        array1[2][3]=2;
        //输出原始数组
        System.out.println("输出原始数组:");
        for (int[] ints : array1){
            for (int anInt : ints){
                System.out.print(anInt+"\t");
            }
            System.out.println();
        }
        //有效数字的个数
        int sum = 0;
        for (int i = 0 ;i<11;i++){
            for (int j = 0;j<11;j++){
                if (array1[i][j]!=0){
                    sum++;
                }

            }
        }
        System.out.println("有效数的个数为:"+sum);
        //创建一个稀疏数组
        int [][] array2 = new int[sum+1][3];//有效数+1为竖列,3为行,列,值
        array2[0][0] = 11;  //11行
        array2[0][1] = 11;  //11列
        array2[0][2] = sum; //有效数字

        int count = 0;     //计数器
        for (int i = 0;i<array1.length;i++){
            for (int j = 0;j<array1[i].length;j++){
                if(array1[i][j]!=0){
                    count++;
                    array2[count][0]=i;
                    array2[count][1]=j;
                    array2[count][2]=array1[i][j];

                }
            }
        }
        for (int i = 0;i<array2.length;i++){
            System.out.println(array2[i][0]+"\t"
                    +array2[i][1]+"\t"
                    +array2[i][2]+"\t");
        }


    }

}
][2] = sum; //有效数字

        int count = 0;     //计数器
        for (int i = 0;i<array1.length;i++){
            for (int j = 0;j<array1[i].length;j++){
                if(array1[i][j]!=0){
                    count++;
                    array2[count][0]=i;
                    array2[count][1]=j;
                    array2[count][2]=array1[i][j];

                }
            }
        }
        for (int i = 0;i<array2.length;i++){
            System.out.println(array2[i][0]+"\t"
                    +array2[i][1]+"\t"
                    +array2[i][2]+"\t");
        }


    }

}

在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值