Java用Arrays.fill()初始化二維數(shù)組的實(shí)現(xiàn)
在最短路徑問(wèn)題上遇到了一個(gè)問(wèn)題,對(duì)于二維int數(shù)組 map[][],需要初始化為int的最大值,不想用雙重循環(huán)賦初值,想用Arrays.fill()填充但是失敗了。。。。。。
首先說(shuō)明,Arrays.fill()并不能提高賦值的效率,在函數(shù)的內(nèi)部也是用for循環(huán)的方式 實(shí)現(xiàn)的。fill()函數(shù)源碼:
public static void fill(Object[] a, Object val) { for (int i = 0, len = a.length; i < len; i++) a[i] = val; }
由此可見(jiàn)fill()函數(shù)只能填充一維數(shù)組,如果這樣用,肯定會(huì)失敗的。
int[][] map=new int[4][5];Arrays.fill(map,-1);//失敗
但是可以換一種方法實(shí)現(xiàn),二維數(shù)組其實(shí)就是一維數(shù)組的數(shù)組,即,它本身只是一個(gè)一維數(shù)組,但是數(shù)組中的每個(gè)變量也是一個(gè)一維數(shù)組。
所以既然它是一維數(shù)組,就可以用對(duì)應(yīng)類(lèi)型的變量來(lái)填充它,即用一個(gè)一維數(shù)組來(lái)填充它:
int[][] map=new int[4][5]; int[] ten=new int[10]; Arrays.fill(ten, -1); Arrays.fill(map,ten); //成功
這里值得注意的是,一旦用ten填充了map,那map聲明時(shí)候的“5”將起不到任何作用,每個(gè)map[i]都將等于ten。
雖然成功填充了二維數(shù)組,但是感覺(jué)好像把問(wèn)題變得更復(fù)雜了,可能并不如直接用for循環(huán)實(shí)現(xiàn)簡(jiǎn)單。
不過(guò)在下面這種情況下,還是很實(shí)用的:
int[][] map=new int[4][5];int[] ten={1,2,6,3,6,1,7};Arrays.fill(map,ten);
當(dāng)ten中的數(shù)值不固定,也不一定有規(guī)律時(shí),可以用Arrays.fill()來(lái)填充二維數(shù)組,使其每一行都是{1,2,6,3,6,1,7}多謝指正,并不能用以上方法給二維數(shù)組賦值,因?yàn)閙ap的每一項(xiàng)指向的都是同一個(gè)一維數(shù)組ten。修改一個(gè)會(huì)影響其他地址的值 ,修改map[0][1] = 100 ,則 map[1][1] map[2][1]等都是100.
到此這篇關(guān)于Java用Arrays.fill()初始化二維數(shù)組的實(shí)現(xiàn)的文章就介紹到這了,更多相關(guān)Java 初始化二維數(shù)組內(nèi)容請(qǐng)搜索好吧啦網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持好吧啦網(wǎng)!
相關(guān)文章:
1. xpath簡(jiǎn)介_(kāi)動(dòng)力節(jié)點(diǎn)Java學(xué)院整理2. 解析原生JS getComputedStyle3. XHTML 1.0:標(biāo)記新的開(kāi)端4. JSP的Cookie在登錄中的使用5. HTML DOM setInterval和clearInterval方法案例詳解6. 詳解瀏覽器的緩存機(jī)制7. 詳解盒子端CSS動(dòng)畫(huà)性能提升8. 測(cè)試模式 - XSL教程 - 59. 讀大數(shù)據(jù)量的XML文件的讀取問(wèn)題10. ASP實(shí)現(xiàn)加法驗(yàn)證碼
