首页 > 其他分享 >数组

数组

时间:2023-07-29 09:13:23浏览次数:37  
标签:String int 元素 数组 new Man

数组定义

数组是相同类型数据有序集合。其中每个数据称为元素,每个元素可以通过索引(下标)来访问。索引(index)

数组的基本特点

  1. 长度是确定的。数组一旦被创建,他的大小就是不可以改变的
  2. 其元素的类型必须相同,不允许出现混合类型
  3. 数组类型可以是任何数据类型,包括基本类型和引用类型
  4. 数组变量属于引用类型。数组也是对象,数组中的元素相当于对象的属性

数组的定义

声明数组和初始化

  1. 声明数组(两种声明方式)
    type[] arr_name;
    type arr_name[]
    
  2. 给数组分配内存空间
  3. 为数组元素赋值

注意事项

  • 声明的时候并没有实例化任何对象,只是在实例化数组对象时,JVM才分配空间,这时才与长度有关
  • 声明一个数组的时候并没有数组真正被创建
  • 构造一个数组,必须指定长度

创建一个基本数据类型的数组

    public static void main(String[] args) {
       int[] s;//声明数组
       s = new int[10];//给数组分配空间

       System.out.println(s[0]);
       System.out.println(s[1]);

       for (int i = 0;i<10;i++){
           s[i] = 2*i+1;//给数组元素赋值;数组是对象,元素是属性
           System.out.println(s[i]);
       }
   }

创建一个引用类型的数组

   Man[] mans;
   mans = new Man[3];
   Man man1 = new Man("sanjin", 19);
   Man man2 = new Man("yuxin", 80);

   mans[0] = man1;
   mans[1] = man2;

   for (int i = 0;i<3;i++){
   	System.out.println(mans[i]);
   }
  1. 数组初始化的方式(4种)
  • 静态初始化
  int [ ] a = { 1, 2, 3 };// 静态初始化基本类型数组;
  Man[ ] mans = { new Man(1, 1), new Man(2, 2) };// 静态初始化引用类型数组;
  • 动态初始化
  int[ ] a1 = new int[2];//动态初始化数组,先分配空间;
  a1[0]=1;//给数组元素赋值;
  a1[1]=2;//给数组元素赋值;
  • 默认初始化
    数组是对象,它的元素相当于对象的属性;每个元素也按照属性的方式被默认初始化。
  int a2[ ] = new int[2]; // 默认值:0,0
  boolean[ ] b = new boolean[2]; // 默认值:false,false
  String[ ] s = new String[2]; // 默认值:null, null

数组的遍历与拷贝

遍历指的就是“通过循环遍历数组的所有元素”。
拷贝指的是将某个数组的内容拷贝到另一个数组中.

遍历

数组元素下标的合法区间:[0, length-1]。我们可以通过下标来遍历数组中的元素,遍历时可以读取元素的值或者修改元素的值。

  1. for循环初始化和遍历数组
       for (int i=0;i<cities.length;i++){
           System.out.println(cities[i]);
       }
  1. for-each遍历读取数组
        for (String city:
             cities) {
            System.out.println(city);
        }

拷贝

使用函数System.arraycopy(object src,int srcpos,object dest, int destpos,int length)该方法可以将src数组里的元素值赋给dest数组的元素,其中srcpos指定从src数组的第几个元素开始赋值,length参数指定 将src数组的多少个元素赋给dest数组的元素。

    public static void main(String[] args) {
        String[] s = {"aa","bb","cc","dd","ee"};
        String[] dest = new String[6];

        System.arraycopy(s,0,dest,0,5);

        for (int i=0;i<dest.length;i++){
            System.out.println(dest[i]);
        }
    }

java.utils.Arrays类

Arrays类包含了:排序、查找、填充、打印内容等常见的数组操作。

  1. 输出数组的元素
    public static void main(String[] args) {
       String[] s = {"aa","bb","cc","dd","ee"};

       System.out.println(s);
       System.out.println(Arrays.toString(s));
   }
  1. 对数组元素进行排序
    Arrays.sort(数组名);

标签:String,int,元素,数组,new,Man
From: https://www.cnblogs.com/sorrymine/p/17586717.html

相关文章

  • golang打印指针切片/数组的值
     FmtSlice2String方法可以将指针切片的值打印处理packagemainimport( "fmt" "reflect")typeStudentstruct{ Namestring`json:"name"cn:"名字"` Ageuint64`json:"age"cn:"年龄"`}funcmain(){ s:=mak......
  • 寻找数组中重复的数字
    寻找数组中重复的数字​ 给定一个包含n+1个整数的数组nums,其数字都在[1,n]范围内(包括1和n),可知至少存在一个重复的整数。假设nums只有一个重复的整数,返回这个重复的数。1<=n<=\(10^5\)nums.length==n+11<=nums[i]<=nnums中只有一个整数出......
  • 树状数组的扩展应用
    「观前提醒」「文章仅供学习和参考,如有问题请在评论区提出」目录O(N)建树方法一方法二维护区间和单点修改,区间查询区间修改,单点查询区间修改,区间查询维护二维子矩阵和(二维树状数组)单点修改,子矩阵查询子矩阵修改,单点查询子矩阵修改,子矩阵查询求逆序对个数求数列中小于x的元......
  • 代码随想录算法训练营第四十天| 300.最长递增子序列 674. 最长连续递增序列 718.
    300.最长递增子序列要求:可以删减任意个节点,最后保存最大的递增长度难点:410489如何保证全局的视角,看到很前面的节点是否大于当前的节点,而不是仅仅记录状态思路:dp[n],当子序列的末尾为N时,它的最大子序列长度也就意味着,N在它的子序列中是最大的,遍历这个N之前的所有序......
  • 【go语言】2.2.1 数组和切片
    数组和切片是Go语言中常用的数据结构,它们都可以存储多个同类型的元素。数组数组是具有固定长度的数据类型,它的长度在定义时就已经确定,不能随意改变。你可以使用以下方式定义一个数组:vararr[3]int这段代码定义了一个长度为3的 int 类型数组 arr。你也可以在定义时初......
  • 代码随想录算法训练营第二天| LeetCode 977.有序数组的平方 ,209.长度最小的子数组 ,59.
    977.有序数组的平方     题目链接:https://leetcode.cn/problems/squares-of-a-sorted-array/    文章讲解:https://programmercarl.com/0977.%E6%9C%89%E5%BA%8F%E6%95%B0%E7%BB%84%E7%9A%84%E5%B9%B3%E6%96%B9.html    视频讲解: https://www.bili......
  • [代码随想录]Day02-数组part02
    题目:977.有序数组的平方思路:一开始的思路是从中间向两边扩:找到第一个大于等于0的位置r;判断nums[r]是否大于等于0,如果不是赋值为len(nums)表示不在范围内了。l的位置在r的左侧因此l=r-1只要l>=0或者r<len(nums)满足一个就可以继续;遍历时要保证数组不能越界说实话维护......
  • 2023-07-27:最长可整合子数组的长度, 数组中的数字排序之后,相邻两数的差值是1, 这种数组
    2023-07-27:最长可整合子数组的长度,数组中的数字排序之后,相邻两数的差值是1,这种数组就叫可整合数组。给定一个数组,求最长可整合子数组的长度。答案2023-07-27:算法maxLen的过程如下:1.检查输入数组是否为空,如果为空,则返回0,表示最长可整合子数组长度为0。2.初始化长度为1的最长......
  • Java 使用数组给对象赋值
    Java使用数组给对象赋值在Java中,我们可以使用数组来给对象赋值。这是一种常见的操作,特别是在处理大量数据时非常有用。在本篇文章中,我将教会你如何使用数组给对象赋值,以及每一步需要做什么。流程概述在开始之前,让我们先来了解一下整个操作的流程。下表展示了用于给对象赋值的步......
  • C#中将字符串分割成字符数组
    在C#中字符串类型String是由一系列的单个字符组合而成,其实可以通过字符串String对象ToCharArray()方法来将字符串中的元素逐一存在数据类型为Char的一维数组中。例如将字符str="ABCDEFG"分割为到一维数组可用下列语句:stringstr="ABCD";char[]strCharArr=str.ToC......