• java基础学习04(数组与方法)


    数组与方法

    一、完成的目标

    1. 掌握数组的定义、使用方法、引用传递
    2. 掌握方法及其方法的重载
    3. 使用方法接收和返回一个数组
    4. java新特性对数组的操作支持
    

    二、数组的定义和使用

    数组是一组相关数据的集合,一个数组实际上就是一连串的变量,数组可以分为一维数组、二维数组、多维数组。

    一维数组
    一维数组可以存放很多数据,这些数据的类型是完全相同的。使用Java数组必须经过两个步骤:声明数组、分配内存给数组。

    数据类型 数组名 [] = null; //声明一维数组
    
    也可以使用如下声明:
    数据类型 [] 数组名 = null; //声明一维数组
    
    数组名 = new 数据类型 [长度];//分配内存给数组
    

    数组的声明格式里,“数据类型”是声明数组元素的数据类型,常见的类型有整型、浮点型与字符型等。“数组名”是用来统一这组相同数据类型的元素的名称,其命名规则和变量的相同。

    数组声明后实际上是在栈内存中保存了此数组的名称,接下来便是要在堆内存中配置数组所需的内存,其中“长度”是告诉编译器,所声明的数组要存放多少个元素,而“new”则是命令编译器根据括号里的长度开辟空间。

    int score [] = null; //声明整型数组score  
    score = new int [3]; //为整型数组score分配内存空间,元素个数位3
    

    声明一个整型数组score时,score并没有包含任何内容,编译器只会在栈内存中分配一块内存给它,用来保存指向数组实体的地址名称。  
    堆内存分配操作,一个数组开辟了堆内存之后,将在堆内存中保存数据,并将堆内存的操作地址给了数组名称score。 

    堆、栈内存理解:一个堆内存可被多个栈内存空间指向,好比一个人(堆内存)有多个名字(栈内存)。 

    声明数组同时分配内存:

    数据类型 数组名 [] = new 数据类型[个数]; //声明一维数组  
    
    int num [] = new int[10];
    

    数组排序
    在数组的操作中,数组的排序是一种很常见的操作。

    /**
    *1.对整型数组按照由小到大的顺序进行排列(冒泡排序)
    *2.冒泡排序:把数组中的每一个元素进行比较,如果第i个元素大于第i+1个元素,那么就把两个数字进行交换
    */
    class TestDemo{
        public static void main(String [] args){        
            int score [] = {69,79,87,89,100,75,90};  //定义整型数组
            System.out.println("***比较开始***");
            for(int i=1;i<score.length;i++){        //循环判断
                for(int j=0;j<score.length;j++){
                    if(score[i] < score[j]){        //交换位置
                        int temp = score[i];
                        score[i] = score[j];
                        score[j] = temp;
                    }
                }
                System.out.print("第"+i+"轮"+"排序结果:");
                for(int j=0;j<score.length;j++){
                    System.out.print(score[j]+"	");
                }   
                System.out.println();
            }
    
            System.out.print("从小到大的排序最终结果:");       
            for(int i=0;i<score.length;i++){
                System.out.print(score[i]+"	");
            }   
        }
    }
    
    Process started >>>
    ***比较开始***
    第1轮排序结果:69  100 79  87  89  75  90  
    第2轮排序结果:69  79  100 87  89  75  90  
    第3轮排序结果:69  79  87  100 89  75  90  
    第4轮排序结果:69  79  87  89  100 75  90  
    第5轮排序结果:69  75  79  87  89  100 90  
    第6轮排序结果:69  75  79  87  89  90  100 
    从小到大的排序最终结果:69  75  79  87  89  90  100 <<< Process finished. (Exit code 0)


    /*
    *1.冒泡排序另外一种方法
    */
    
    public class BubbleSortTest
    {
        public static void  bubbleSort(int [] a)
        {
            for(int i = 0 ;i < a.length - 1;i++)
            {
                for(int j = 0;j < a.length - i - 1;j++ )
                {
                    if(a[j] > a[j+1])
                    {
                        int temp = a[j+1];
                        a[j+1] = a[j];
                        a[j] = temp;
                    }
                }
                System.out.println("第"+(i + 1)+"轮循环:");
                for(int k = 0 ;k < a.length; k++)
                {
                    System.out.print(a[k]+" ");
                }
                System.out.println();
            }
        }
        public static void main(String[] args)
        {
            int [] a = {2,7,6,9,5,3};
            bubbleSort(a);
        }
    }
    
    Process started >>>
    第1轮循环:
    2 6 7 5 3 9 
    第2轮循环:
    2 6 5 3 7 9 
    第3轮循环:
    2 5 3 6 7 9 
    第4轮循环:
    2 3 5 6 7 9 
    第5轮循环:
    2 3 5 6 7 9 
    <<< Process finished. (Exit code 0)

    方法的递归调用 
    递归调用是一种特殊的调用形式,是方法自己调用自己。

    /**
    *1.方法的递归调用
    */
    class TestDemo{
        public static void main(String [] args){        
            System.out.println("***计算结果***"+sum(100));//调用操作
        }
        public static int sum(int num){     //定义方法用于求和操作
            if(num == 1){                   //判断是否加到最后一个数
                return 1;
            }else{
                return num + sum(num - 1);  //递归调用
            }
        }
    }
    
    Process started >>>
    ***计算结果***5050
    <<< Process finished. (Exit code 0)
  • 相关阅读:
    多选菜单shell脚本
    获取nginx日志状态码百分比脚本
    Linux内核参数优化
    deploy.sh
    Docker常用命令速查
    Docker架构
    修改Docker默认存储路径
    redis安装与基本使用
    js实现汉字转拼音
    android:Android 6.0+ 权限控制代码封装
  • 原文地址:https://www.cnblogs.com/billyzh/p/5317624.html
Copyright © 2020-2023  润新知