如何使用Comparator和迭代器对Integer Vector进行排序?

时间:2013-12-23 08:41:16

标签: java iterator compareto

我想创建Integer矢量类型Vector并插入随机10个数字。

然后我想使用VectorcompareTo进行排序,并发送两个参数类型数字进行比较。

但我想念一些事。 非常感谢任何帮助。

    import java.util.*;

public class SortNumeric implements Comparable<SortNumeric>
{
   private int ind =0;

   public static void main(String args[])
    {
        Vector<Integer> vec = new Vector<>();

        System.out.println("Befor sorting");
        for (int index = 0; index < 10; index++)
        {
            int rand = (int)(1000*Math.random());
            vec.add(rand);
             System.out.println(rand);
        }

        Arrays.sort(vec);

        System.out.println("After sorting");
        for(Integer intnum : vec)
         {
         System.out.println(intnum);
         }

    }

    public int getNextCompar(){
          if (vec.hasNext() && this.ind < 5){
            this.ind++;
            return vec.next();
        }else{return 0;}
     }

     public int compareTo(SortNumeric other)
            {
                return (int) (vec.next() - this.getNextCompar());

            }

}

3 个答案:

答案 0 :(得分:1)

class sortVectors implements Comparator<Integer>{

    @Override
    public int compare(Integer o1, Integer o2) {
        // TODO Auto-generated method stub
        if(o1<02){
            return -1;
        }else if(o1>o2)
            return 1;
            return 0;
    }
}
public class sortVector{
    public static void main(String[] args) {
        // TODO Auto-generated method stub
         Vector<Integer> vect = new Vector<Integer>();
            System.out.println("Befor sorting");
            for (int index = 0; index < 10; index++) {
                int rand = (int) (1000 * Math.random());
                vect.add(rand);
                System.out.println(rand);
            }
        Collections.sort(vect,new sortVectors());
        System.out.println("After Sorting");
        for (Integer num : vect) {
            System.out.println(num);
        }

    }

}

答案 1 :(得分:0)

如果要按特定顺序对数组进行排序,则需要创建比较器。

当您想要在集合或数组中使用时对特定类的对象进行排序时,可以使用Comparable。

在您的情况下,您需要使用比较器。

class MyComparator extends Compartor
{
  public int compare(Integer a, Integer b)
  {
            return a - b;
  }
}

在您的Main类中,调用Arrays.sort(vec,new MyComparator());

答案 2 :(得分:0)

您无需为Comparable实施Integer,因此不需要compareTo。也可以使用Collections.sort代替Arrays.sort。这是您修改过的代码示例:

import java.util.Collections;
import java.util.Vector;

public class Main {
    public static void main(String args[]) {
        Vector<Integer> vec = new Vector<>();
        System.out.println("Befor sorting");
        for (int index = 0; index < 10; index++) {
            int rand = (int) (1000 * Math.random());
            vec.add(rand);
            System.out.println(rand);
        }

        Collections.sort(vec);

        System.out.println("After sorting");
        for (Integer intnum : vec) {
            System.out.println(intnum);
        }
    }
}

检查此问题以获取更多详细信息:

What function can be used to sort a Vector?