java数组整理笔记

数组介绍

  1. 数组就是相同类型的数据的有序组合,包含多个数组元素,每个元素都能通过下标获取,下标为0-数组长度(arrays.length);
  2. 数组的元素可以是8种类型中的任意一种,或是引用类型,但是同一个数组中的所有元素类型都必须相同,不可a[0]是int型,a[1]是char型;
  3. 动态初始化:int[] a =new a[10];未赋值的数组元素默认为0;
  4. 静态初始化:int[] a={1,2,3,4,5,6};
  5. 数组元素通过下标引用,如a[0];

二维数组

  1. 数组定义声明:int [][] arraysTwo ={{1,2},{1,5},{3,5},{4,55},{3,444}};
  2. 如何取值,通过下标如arraysTwo[0][0];
  3. 代码示例:
java 复制代码
package ArraysTest;

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

工具类Arrays

  1. 打印元素;Arrays.toString(a);
  2. 排序:Arrays.sort(a);
  3. 填充:Arrays.fill(a,2, 4, 0);
java 复制代码
package ArraysTest;
import  java.util.Arrays;

public class ArraysDemo05 {
    static void main(String[] args) {
        int[] a={1,3,5,6,8,2,22,11,2};
        //打印数组元素
        System.out.println(Arrays.toString(a));
        Arrays.sort(a);//排序
        System.out.println(Arrays.toString(a));
        Arrays.fill(a,2, 4, 0);//填充,下标2-4之间的填充0,即a[2] a[3]填充0;
        System.out.println(Arrays.toString(a));
    }
}

冒泡排序

  1. 两层循环,第一层排序轮数,第二层比较前一个数和后一个数的大小,大的排前,小的排后,按照从大到小的排序;java代码如下:
java 复制代码
package ArraysTest;
import java.util.Arrays;

public class ArraysDemo06 {
    static void main(String[] args) {
        int[] a={50,3,5,6,8,255,22,11,2};
        int[]aa=sortTest(a);
        System.out.println(Arrays.toString(aa));
    }
    public static  int[] sortTest(int[] a){
        int temp ;
        //比较的轮数。
        for (int i=0;i<a.length-1;i++){
            //比较,后面的比前面大则交换,那么就是相当按照从大到小排序;
            for (int j=0;j<a.length-1-i;j++){
                if (a[j+1]>a[j]){
                    temp=a[j];
                    a[j]=a[j+1];
                    a[j+1]=temp;
                }
            }
        }
        return a;
    }
}

稀疏数组

  1. 同一个数组中大部分元素都是0(或是其他的同一个值时),可以用稀疏数组表示,节省资源;
  2. 如原数组如下:
java 复制代码
package ArraysTest;
import java.util.Arrays;

public class ArraysDemo07 {
    static void main(String[] args) {
         int[][] arrays1 =new int[11][11];
        arrays1[2][2] =1;
        arrays1[0][3] =2;
        for (int i = 0; i< arrays1.length; i++){
            for (int j = 0; j< arrays1[i].length; j++){
                System.out.print(arrays1[i][j]+"\t");
            }
            System.out.println();
        }
    }
}
  1. 转换稀疏数组如下:
java 复制代码
package ArraysTest;

public class ArraysDemo07 {
    static void main(String[] args) {
        int[][] arrays1 = new int[11][11];
        arrays1[2][2] = 1;
        arrays1[0][3] = 2;
        System.out.println("原数组如下:");
        for (int i = 0; i < arrays1.length; i++) {
            for (int j = 0; j < arrays1[i].length; j++) {
                System.out.print(arrays1[i][j] + "\t");
            }
            System.out.println();
        }
        //转换为稀疏数组,先获取有效值个数
        int count1 = 0;
        for (int i = 0; i < arrays1.length; i++) {
            for (int j = 0; j < arrays1[i].length; j++) {
                if (arrays1[i][j] != 0) {
                    count1++;
                }
            }
        }
        System.out.println("数组arrays有效值个数" + count1);
        //创建稀疏数组,赋值第一行的值
        int[][] arrays2 = new int[count1 + 1][3];
        arrays2[0][0] = 11;
        arrays2[0][1] = 11;
        arrays2[0][2] = count1;
        //遍历原数组,将非零的值,存在稀疏数组中
        int count2 = 0;
        for (int i = 0; i < arrays1.length; i++) {
            for (int j = 0; j < arrays1[i].length; j++) {
                if (arrays1[i][j] != 0) {
                    count2++;
                    arrays2[count2][0] = i;
                    arrays2[count2][1] = j;
                    arrays2[count2][2] = arrays1[i][j];
                }
            }
        }
        //输出稀疏数组
        System.out.println("稀疏数组如下:");
        for (int i= 0; i < arrays2.length; i++) {
            for (int j = 0; j < 3; j++) {
                System.out.print(arrays2[i][j] + "\t");
            }
            System.out.println();
        }
    }
}
相关推荐
Aision_3 小时前
从工具调用到 MCP、Skill完整学习记录
java·python·gpt·学习·langchain·prompt·agi
辞旧 lekkk7 小时前
【Qt】信号和槽
linux·开发语言·数据库·qt·学习·mysql·萌新
zc.z7 小时前
JAVA实现:纯PCM格式音频转换成BASE64
java·音视频·pcm
mask哥7 小时前
力扣算法java实现汇总整理(上)
java·算法·leetcode
2zcode7 小时前
运动模糊图像复原的MATLAB仿真与优化
开发语言·matlab
袁雅倩19978 小时前
当吸尘器、筋膜枪都用上Type-C,供电方案该怎么选?浅谈PD取电芯片ECP5702的应用
c语言·开发语言·支持向量机·动态规划·推荐算法·最小二乘法·图搜索算法
Aaswk8 小时前
Java Lambda 表达式与流处理
java·开发语言·python
是宇写的啊9 小时前
Spring AOP
java·spring
万邦科技Lafite9 小时前
京东item_get接口实战案例:实时商品价格监控全流程解析
java·开发语言·数据库·python·开放api·淘宝开放平台
Cyber4K10 小时前
【Python专项】进阶语法-系统资源监控与数据采集(1)
开发语言·python·php