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};

解决方案 »

  1.   

    看看这个:
    http://topic.csdn.net/u/20120928/18/76dd91ac-7e2a-47dd-acc5-75cfb1d858b3.html
      

  2.   

    看看这个: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)); // 显示。
    }
    }
      

  3.   

    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]);
     }
       }
    }
      

  4.   


    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()));
    }
      

  5.   

    [Java code]
    //先试试这个好不好使
    [/Java code]
      

  6.   

    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());
      }
     
     
      }
      

  7.   

    用HashSet或HashMap都可以。。百度一下用法。。
      

  8.   

    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];}
    array1[z]=array[array.length-1];//最后一个数8用这个循环无法放入array1数组当中

    }

    for(int i=0;i<=z;i++)
    { System.out.print(array1[i]);}//输出
          }
    }
    你看看吧!