3 回答

TA貢獻1804條經驗 獲得超7個贊
ArrayList 操作
您可以從O(1) 中的an中獲取一個值并ArrayList
在 O(1) 中添加一個值。此外,ArrayList
已經內置了可幫助您檢索和添加元素的操作。
字符串操作
Concatenation:使用 concat 和 slice 操作,結果會更糟。字符串粗略地說是字符數組。例如,"Hello" + "Stack" 可以表示為 array['H', 'e', 'l', 'l', 'o']
和 array ['S', 't', 'a', 'c', 'k']
?,F在,如果要連接這兩個String
,則必須組合兩個數組的所有元素。它會給你一個長度為 10 的數組。因此,連接 - 或創建你的新字符數組 - 是O(n + m)
.
最糟糕的是,如果您連接 n String
,您的復雜度將為O(n^2)
。
拆分:拆分字符串的復雜度通常為O(N)
或更多。這取決于您將為拆分操作提供的正則表達式。
操作String
通常不那么可讀,并且很難調試。
長話短說
AnArrayList
通常比使用 操作更好String
。但一切都取決于您的用例。

TA貢獻1951條經驗 獲得超3個贊
只需使用 ArrayList,它存儲對您的對象值的引用,并且引用一點也不大,這就是使用引用的重點。我一直想知道為什么要將值存儲在 String 中……這很奇怪。ArrayList 存儲值并獲取它們足夠快,并且 String 實現,內部也使用數組...所以...使用 ArrayList。
添加回答
舉報