java数组拼接

java数组拼接JAVA数组拼接(扩容)int[]A=newint[]{1,3,5,7,9};int[]B=newint[]{2,4,6,8,10};arrayJoin(A,B);}publicstaticvoidarrayJoin(int[]a,int[]b){int[]arr=newint[a.l…

大家好,又见面了,我是你们的朋友全栈君。

JAVA数组拼接(扩容)

        int[] A=new int[]{ 
   1,3,5,7,9};
        int[] B=new int[]{ 
   2,4,6,8,10};
        arrayJoin(A,B);
    }
    public static void arrayJoin(int[] a,int[] b){ 
   
        int[] arr=new int[a.length+b.length];//开辟新数组长度为两数组之和
        for(int i=0;i<a.length;i++){ 
   //拷贝a数组到目标数组arr
             arr[i]=a[i];
        }
        for(int j=0;j<b.length;j++){ 
   //拷贝b数组到目标数组arr
            arr[a.length+j]=b[j];
        }
        for(int i=0;i<arr.length;i++){ 
   //输出目标数组
            System.out.print(arr[i]+" ");
        }
    }
}

java数组拼接

实际在java中可用java.util.Arrays.copyOf(源数组名称,新数组长度)命令直接实现数组扩容。

public class Day12_2{ 
   
    public static void main(String[] args){ 
   
        int[] A=new int[]{ 
   1,3,5,7,9};
        int[] B=new int[]{ 
   2,4,6,8,10};
        int[] result=java.util.Arrays.copyOf(A,10);
        //使result数组长度为10,并将A数组拷贝至新数组,此时result数组与原数组不是同一块内存,原来的内存还是5个元素,result的是扩容后的空间
        for(int x=0;x<B.length;x++){ 
   
            result[A.length+x]=B[x];
        }
        for(int i:result){ 
   
            System.out.print(i+" ");
        }
        System.out.print("");//换行
    }
}

java数组拼接

public class Day12_2{ 
   
    public static void main(String[] args){ 
   
        int[] A=new int[]{ 
   1,3,5,7,9};
        int[] B=new int[]{ 
   2,4,6,8,10};
        int[] result=java.util.Arrays.copyOf(A,10);//动态扩容,数值为java int默认值0
        // for(int x=0;x<B.length;x++){ 
   
        // result[A.length+x]=B[x];
        // }
        for(int i:result){ 
   
            System.out.print(i+" ");
        }
        System.out.print("");
    }
}

java数组拼接

上述讲到的是java中数组拷贝的模拟实现和自行实现语句,那么既然有数组完整拷贝肯定也就有数组部分拷贝。所以数组部分拷贝的语句是

System.arraycopy(源数组名称,源数组开始点,目标数组名称,目标数组开始点,拷贝长度)

但一定要注意的是目标数组拷贝位置确定后是连续拷贝的。

public class Day12_2{ 
   
    public static void main(String[] args){ 
   
        int[] A=new int[]{ 
   1,2,3,4,5,6,7,8};
        int[] B=new int[]{ 
   22,102,45,34,67,89,122};
        System.arraycopy(B,2,A,4,3);//源数组为B(将数组B部分元素拷贝至A数组),拷贝起始点下标为2,即从45开始拷贝;A数组拷贝开始点为下标为4,即从5开始更改数组内容,拷贝长度为3
        for(int i:A){ 
   //用foreach语句输出数组A
            System.out.print(i+" ");
        }
        System.out.print("");
    }
}

java数组拼接

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/130944.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • python 2022.01.13 激活【2021最新】

    (python 2022.01.13 激活)本文适用于JetBrains家族所有ide,包括IntelliJidea,phpstorm,webstorm,pycharm,datagrip等。IntelliJ2021最新激活注册码,破解教程可免费永久激活,亲测有效,下面是详细链接哦~https://javaforall.net/ide…

    2022年3月31日
    42
  • Netty权威指南_算法笔记上机指南pdf

    Netty权威指南_算法笔记上机指南pdf第1章Java的I/O演进之路1.1Linux网络I/O模型fd:filedescriptor,文件描述符。linux内核将所有外部设备都看作一个文件来操作,对文件的读写会调用内核提供的命令

    2022年8月3日
    8
  • 罗马字符的读音「建议收藏」

    罗马字符的读音「建议收藏」Αα阿尔法alfaΒβ贝塔bitaΓγ伽马gamaΔδ德耳塔dêltaΕε艾普西龙êpsilonΖζ度截塔zitaΗη艾塔yitaΘθ西塔sitaΙι约塔yotaΚκ卡帕kapa∧λ兰布达lamdaΜμ米尤miuΝν纽niuΞξ克西ksaiΟο奥密克戎oumikelong∏π派paiΡρ版若rou…

    2022年9月30日
    3
  • Linux下文件搜索、查找、查看命令

    Linux下文件搜索、查找、查看命令Linux下文件搜索、查找、查看命令1、最强大的搜索命令:find一、根据文件或目录名称搜索二、根据文件大小搜索三、根据所有者和所属组搜索四、根据时间属性搜索五、根据文件类型或i节点搜索六、组合条件搜索  2、在文件资料中查找文件:locate  3、搜索命令所在的目录及别名信息:which 4、搜索命令所在的目录及帮助文档路径:whereis5、在文件…

    2022年7月26日
    11
  • 10款好用的谷歌chrome浏览器插件、扩展程序,用起来很爽哦

    10款好用的谷歌chrome浏览器插件、扩展程序,用起来很爽哦TOP1:AdblockPlus介绍:AdblockPlus是Chrome浏览器中非常流行的一款广告拦截插件,AdblockPlus的用户多达数百万之多,在全球范围内都有很高的使用评价,AdblockPlus是由一个开源社区来维护。TOP2:OfficeEditingforDocs,Sheets&Slides介绍:officeediting是一款可…

    2022年4月29日
    90
  • vs2010打不开vs2017的.sln文件[通俗易懂]

    vs2010打不开vs2017的.sln文件[通俗易懂]出现错误提示“选择的文件是解决方案文件但是用此应用程序的较新版本创建的,无法打开”解决方案:1、复制下面这段语句MicrosoftVisualStudioSolutionFile,FormatVersion11.00#VisualStudio20102、用记事本方式打开vs2017版本的.sln文件,将上面复制的两行语句替换.sln文件里面前两行语句,保…

    2022年5月23日
    250

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号