JAva配列要素の削除と重複配列要素の削除のコード

2710 ワード

配列の削除listの使用{{はいれつのさくじょ:listのしよう}}
 
  
private String[] removePaths(String path, String[] srcpaths) {
  List list = new ArrayList();
  int k = srcpaths.length;//
  int i=0;
  while(i   if(!srcpaths[i].equals(path)){
    list.add(srcpaths[i]);                      // list
   }
   i++;
  }
  String[] temp = new String[list.size()];
  for(int j=0;j   temp[j] = list.get(j);
  }
  return temp;
}

コンパイラがなくて、勝手に書いて、多分その意味でしょう...
 
  
private String[] removePaths(String path, String[] srcpaths) {
    List list = Arrays.asList(srcpaths);
    list.remove(path);
    String[] temp = new String[list.size()];
    return list.toArray(temp);
}

配列内の同じ要素を削除
まずソース配列をデフォルトでソートします
同じ要素を隣接させる
次に、ループ操作を行って同じ要素を削除します.
 
  


<br>var source = [" "," "," "," "," "," "]; <br>var target = new Array(); <br>source.sort(); <br>target.push(source[0]); <p></p> <p>for(var i=1;i<source.length;i++)<br>{<br>if(source[i] != source[i-1])<br>{<br>target.push(source[i]);<br>}<br>}<br>document.write(' :' + source + "<br />");<br>document.write(' :' + target);<br>



2つのインスタンスを追加
 
  
    public static void main(String[] args) {
    getDistinct(new int[] { 6, 7, 3, 6, 5, 2, 7, 8 });
    }
    static void getDistinct(int array[]) {
    java.util.List list = new java.util.ArrayList();
    for (int i = 0; i < array.length; i++) {
    if (!list.contains(array[i])) {
    list.add(array[i]);
    System.out.print(array[i] + " ");
    }
    }
    }

出力:6 7 3 5 8
ArrayListのcontains()メソッドのソースコードを見てみました.
 
  
    public boolean contains(Object elem) {
    return indexOf(elem) >= 0;
    }
    public int indexOf(Object elem) {
    if (elem == null) {
    for (int i = 0; i < size; i++)
    if (elementData[i]==null)
    return i;
    } else {
    for (int i = 0; i < size; i++)
    if (elem.equals(elementData[i]))
    return i;
    }
    return -1;
    }