2012-04-27 108 views
0

我有一個變量數組,我想刪除其中的1個元素,然後將整個數組向下移動以填充被刪除的點。任何幫助將不勝感激,並且在你問之前,不,這不是功課。如何將陣列元素從某個位置向下移動?

+0

你嘗試過什麼嗎?您是否修復了使用數組而不是更靈活的數據結構(如集合)? – 2012-04-27 05:23:03

+0

您可以使用'ArrayList' – Neifen 2012-04-27 05:23:11

+0

發佈一些代碼,以便我們可以更好地理解您的問題。 – 2012-04-27 05:23:12

回答

2

理想情況下,使用ArrayList(或其他列表實現),而不是已經爲您實現的地方。 (您想要使用的具體實現取決於您需要多長時間執行一次清除操作,以及您需要多長時間檢索一次還是按索引設置等等。有了更多的上下文,我們可以幫助您更多。)

否則,使用System.arraycopy

System.arraycopy(array, index + 1, array, index, array.length - index - 1); 
// Assuming it's a reference type array: null out the last element so it 
// doesn't prevent garbage collection 
array[array.length - 1] = null; 
+0

'ArrayList'仍然不是一個好的選擇 - 它仍然需要移動所有元素 – 2012-04-27 05:24:20

+1

@BorisStrandjev:我已經編輯過 - 這取決於你需要多久執行一次這個操作。有很多變量涉及到,基本上 - 我不會在這裏推薦LinkedList,因爲如果OP需要按索引做很多get/set操作,那麼這將會很糟糕。 (它在內存方面的效率也會明顯降低。) – 2012-04-27 05:26:48

+0

很少有人應該在'ArrayList'上使用'LinkedList'。請參閱以下文章(有點舊,但可能仍然相關):[第1條](http://onjava.com/onjava/2001/05/30/optimization.html)和[第2條](http: //www.javaspecialists.eu/archive/Issue111.html)。可能是由於「LinkedList」必須包裝每個元素才能創建元素之間的鏈接 – Robin 2012-04-27 06:07:39

0

在陣列中這樣做會不會是有效的,特別是如果你需要提供數組的萎縮:

  • ,如果你不需要收縮你可以換到最後所有元素。
  • 如果您需要縮小,那麼唯一的選擇是分配新數組並複製所有元素。

該任務的更好選擇是LinkedList。它提供了刪除任意元素的操作,並且它不需要任何移動來固定收集。

0

我認爲最好的解決辦法是使用ArrayList

 ArrayList<String> list = new ArrayList<String>(); 

     //add Elements 
     list.add("test1"); 
     list.add("test2"); 
     list.add("test3"); 

     //remove Element 2 (->1) 
     list.remove(1); 

     //print Element 2 
     System.out.println(list.get(1)); 
     //output: test3 

如果你真的想給我們一個數組:

private void removeElement(String[] array, int index) { 
    final int arrayLength = array.length; 
    for (int i = index + 1; i < arrayLength; i++) { 
     if (i > 0) { 
      array[i - 1] = array[i]; 

      if (i == arrayLength - 1) { 
       array[i] = ""; 
      } 
     } 
    } 
} 
0

一個可能的解決方案是使用Arrays.asListList#toArray方法將陣列暫時轉換爲List,使用List的可用remove方法,並將其轉換回數組。

Object[] arrayToShrink = ...; 
List<Object> shrinkedList = new ArrayList<Object>(Arrays.asList(arrayToShrink)); 
shrinkedList.remove(objectToRemove); 
Object[] shrinkedArray = shrinkedList.toArray(new Object[shrinkedList.size()]); 

短代碼明智,但最有可能不是最有效的解決方案。

+0

你試過這個嗎? Arrays.asList()。remove(...)將拋出。 – 2012-04-27 06:10:15

+0

@JonSkeet好的。不,我沒有嘗試過,但我會糾正答案。似乎我需要額外的一行代碼 – Robin 2012-04-27 06:12:29