日期:2014-05-20  浏览次数:20713 次

新手,求代码
1.请问各位大神怎么样删除数组中的重复元素或者复制一个数组,其中没有重复的元素,
  我初学java的,给个简单点的代码,谢谢!
  比如int[] array = { 1, 2, 3, 4, 6, 8, 2, 1, 3, 5, 1, 2, 6 };
  需要的结果为array2={1,2,3,4,5,6,8};


------解决方案--------------------
看看这个:

import java.util.Arrays;

public class RemoveRep {
public static void main(String[] args) {

int[] array = { 1, 2, 3, 4, 6, 8, 2, 1, 3, 5, 1, 2, 6 };
int[] newNum = new int[array.length]; // 存放没有重复的数组。
int[] array2;
newNum[0] = array[0]; // 第一个元素肯定不重复。
Arrays.sort(array); // 对原数组排序。
int remain = 0;
for (int i = 1, k = 0; i < array.length; i++) {

if (array[i] != newNum[k]) { // 新数组里没有,就放进去。

newNum[++k] = array[i];
remain = k + 1; // 记录无重复元素数。
}

}
array2 = Arrays.copyOf(newNum, remain);// 去掉多余的元素(0)。
System.out.println(Arrays.toString(array2)); // 显示。
}
}

------解决方案--------------------
public class ArrayCacluateTest {
public static void main(String[] args) {
int[] array = new int[]{1,2,3,4,6,8,2,1,3,5,1,2,6};
Set<Integer> set =new HashSet<Integer>();//set集合 重复的数据加不进去。
for(int i =0;i<array.length;i++){
set.add(array[i]);//重复的加不进去。
}
Object[] array3 =set.toArray(); //将集合转化为 Object 类型数组
int[] array2 = new int[set.size()];
for(int i =0;i<array3.length;i++ ){
array2[i]= (Integer)array3[i]; //转化为 int 数组 
}
Arrays.sort(array2); //升序排列了。
// 打印出来。
for(int i = 0 ; i<array2.length;i++){
System.out.println(array2[i]);
}
}
}
------解决方案--------------------
Java code

    public static void main(String[] args) {
        Integer[] i = {1,2,3,4,6,8,2,1,3,5,1,2,6};
        Set<Integer> s = new TreeSet<Integer>(Arrays.asList(i));
        System.out.print(Arrays.toString(s.toArray()));
    }

------解决方案--------------------
public static void main(String[] args) {
  int array[] = { 1, 2, 3, 4, 6, 8, 2, 1, 3, 5, 1, 2, 6 };
  Set<Integer> set = new HashSet<Integer>();
  for (int i = 0; i < array.length; i++) {
  set.add(array[i]);
  }
 
  for(Iterator it = set.iterator();it.hasNext();) {
  System.out.println("value=" + it.next().toString());
  }
 
 
  }
------解决方案--------------------
楼主看的懂的话,这个最简单
探讨

Java code

public static void main(String[] args) {
Integer[] i = {1,2,3,4,6,8,2,1,3,5,1,2,6};
Set<Integer> s = new TreeSet<Integer>(Arrays.asList(i));
System.out.print(A……

------解决方案--------------------
class New
{
public static void main(String[] args)
{
int array[]={1, 2, 3, 4, 6, 8, 2, 1, 3, 5, 1, 2, 6 ,8};
int array1[]=new int[array.length];
int k,z=0,temp;
for(int i=0;i<array.length-1;i++)//对原数组进行排序 
{
for(int j=i;j<array.length;j++)
{
k=i;//存放最小数的下标号
if(array[i]>array[j])
k=j;
if (k!=i)
{temp=array[i];array[i]=array[j];array[j]=temp;}//交换
}

System.out.println();
for(int i=0;i<array.length-1;i++)//把不重复的数字放入array1数组当中

if(array[i]!=array[i+1]) {array1[z++]=array[i];}