在寫程序的過程中,我們常常會碰見數(shù)組空間不夠用的情況,比如我已經(jīng)初始化了一個數(shù)組int []a = {1,2,3,4,5,6,7,8,9,10} ;這時,我想往數(shù)組下標(biāo)3的位置插入一個元素,該怎么做?用C語言實(shí)現(xiàn)太難了吧,需要調(diào)用memcpy函數(shù)要一個一個偏,但是在java中就不用那么麻煩了,有種叫數(shù)組的擴(kuò)容方式,輕松實(shí)現(xiàn)。來看看代碼:
鹿城ssl適用于網(wǎng)站、小程序/APP、API接口等需要進(jìn)行數(shù)據(jù)傳輸應(yīng)用場景,ssl證書未來市場廣闊!成為創(chuàng)新互聯(lián)的ssl證書銷售渠道,可以享受市場價格4-6折優(yōu)惠!如果有意向歡迎電話聯(lián)系或者加微信:18982081108(備注:SSL證書合作)期待與您的合作!
public class HelloWorld { public static void main(String[] args){ // Scanner s = new Scanner(System.in); // System.out.println("請輸入一個數(shù)字"); // int num = s.nextInt(); //這個數(shù)組下標(biāo)只能到9 int []a = {1,2,3,4,5,6,7,8,9,10}; //先擴(kuò)容 int []b = Getarray(a,3,100); Demoe.PrintArray(b); } //案例:有一個數(shù)組已經(jīng)初始化完畢,現(xiàn)向其下標(biāo)3插入一個元素100 public static int[] Getarray(int []a , int index , int num){ int src_array_length = a.length ; int []b = new int[src_array_length+1] ; for(int i = 0 ; i < a.length ; i++){ b[i] = a[i] ; } a = b ; //如果還想使用a,使得a指向b //接下來從最后一個元素開始,將最后一個元素的前面一個元素拷貝到最后一個 //以此類推 for(int i = a.length - 1 ; i > index ; i--){ a[i] = a[i-1]; } //別忘了,將要插入的元素插入到對應(yīng)的數(shù)組坐標(biāo) a[index] = num ; return a ; } }
也可以使用java中的庫函數(shù)來實(shí)現(xiàn)
import java.util.Arrays; public class HelloWorld { public static void main(String[] args){ // Scanner s = new Scanner(System.in); // System.out.println("請輸入一個數(shù)字"); // int num = s.nextInt(); int []a = {1,2,3,4,5}; int []b = new int[a.length] ; //1、源數(shù)組 //2、源數(shù)組的哪個位置開始 //3、目標(biāo)數(shù)組 //4、目標(biāo)數(shù)組的哪個位置開始存放 //5、拷貝幾個 //System.arraycopy(a, 0, b, 0, a.length); //Demoe.PrintArray(b); //擴(kuò)容--->擴(kuò)容了一倍 //a = Arrays.copyOf(a, 2*a.length) ; //Demoe.PrintArray(a); a = insertArray(a , 3 , 100) ; //打印數(shù)組 System.out.println(Arrays.toString(a)); } //寫一個函數(shù),向整數(shù)數(shù)組的任意pos位置插入一個元素value public static int[] insertArray(int []a , int pos , int value){ if(pos < 0 || pos > a.length + 1) //索引下標(biāo)不對,直接返回源數(shù)組 return a ; //放入一個元素,先擴(kuò)容,后復(fù)制 a = Arrays.copyOf(a, a.length+1) ; for(int i = a.length - 1 ; i > pos ; i--){ a[i] = a[i-1] ; //后移動 } a[pos] = value ; return a ; } }
運(yùn)行結(jié)果:
[1, 2, 3, 100, 4, 5]
總結(jié)
以上就是本文關(guān)于Java數(shù)組擴(kuò)容實(shí)例代碼的全部內(nèi)容,希望對大家有所幫助。如有不足之處,歡迎留言指出。感謝朋友們對本站的支持!
本文名稱:Java數(shù)組擴(kuò)容實(shí)例代碼
路徑分享:http://m.rwnh.cn/article40/jejhho.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供企業(yè)建站、標(biāo)簽優(yōu)化、網(wǎng)站營銷、網(wǎng)站導(dǎo)航、手機(jī)網(wǎng)站建設(shè)、關(guān)鍵詞優(yōu)化
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)