it-swarm-pt.tech

como classificar um ArrayList em ordem crescente usando Coleções e Comparador

Como classificar um ArrayList em ordem crescente usando Comparator? Eu sei como classificá-lo em ordem decrescente usando:

Comparator mycomparator = Collections.reverseOrder();

então

Collections.sort(myarrayList,mycomparator);

só quero saber como classificá-lo em ordem crescente usando Coleções e comparador? Obrigado!

5
user1097097

Apenas jogando isso lá fora ... Você não pode simplesmente fazer:

Collections.sort(myarrayList);

Já faz um tempo ...

22
Cody S

Use a versão padrão:

Collections.sort(myarrayList);

Obviamente, isso exige que seus Elementos implementem Comparable, mas o mesmo vale para a versão que você mencionou.

BTW: você deve usar genéricos em seu código, para obter erros em tempo de compilação, se sua classe não implementar Comparable. E os erros em tempo de compilação são muito melhores do que os erros de tempo de execução que você obterá de outra forma.

List<MyClass> list = new ArrayList<MyClass>();
// now fill up the list

// compile error here unless MyClass implements Comparable
Collections.sort(list); 
9
Sean Patrick Floyd

Classificar por valor

  public Map sortByValue(Map map, final boolean ascending) {
            Map result = new LinkedHashMap();
            try {
                List list = new LinkedList(map.entrySet());

                Collections.sort(list, new Comparator() {
                    @Override
                    public int compare(Object object1, Object object2) {
                        if (ascending)
                            return ((Comparable) ((Map.Entry) (object1)).getValue())
                                    .compareTo(((Map.Entry) (object2)).getValue());
                        else
                            return ((Comparable) ((Map.Entry) (object2)).getValue())
                                    .compareTo(((Map.Entry) (object1)).getValue());

                    }
                });

                for (Iterator it = list.iterator(); it.hasNext();) {
                    Map.Entry entry = (Map.Entry) it.next();
                    result.put(entry.getKey(), entry.getValue());
                }

            } catch (Exception e) {
                Log.e("Error", e.getMessage());
            }

            return result;
        }
1
user1140237

Aqui está um exemplo completo:

Suponha que tenhamos uma classe Person como:

public class Person
{
    protected String fname;
    protected String lname;

    public Person()
    {

    }

    public Person(String fname, String lname)
    {
        this.fname = fname;
        this.lname = lname;
    }

    public boolean equals(Object objet)
    {
        if(objet instanceof Person)
        {
            Person p = (Person) objet;
            return (p.getFname().equals(this.fname)) && p.getLname().equals(this.lname));
        }
        else return super.equals(objet);
    }

    @Override
    public String toString()
    {
        return "Person(fname : " + getFname + ", lname : " + getLname + ")";
    }

    /** Getters and Setters **/
}

Agora criamos um comparador:

import Java.util.Comparator;

public class ComparePerson implements Comparator<Person>
{
    @Override
    public int compare(Person p1, Person p2)
    {
        if(p1.getFname().equalsIgnoreCase(p2.getFname()))
        {
            return p1.getLname().compareTo(p2.getLname());
        }
        return p1.getFname().compareTo(p2.getFname());
    }
}

Por fim, suponha que tenhamos um grupo de pessoas:

import Java.util.ArrayList;
import Java.util.Collections;
import Java.util.Comparator;
import Java.util.List;

public class Group
{
    protected List<Person> listPersons;

    public Group()
    {
        this.listPersons = new ArrayList<Person>();
    }

    public Group(List<Person> listPersons)
    {
        this.listPersons = listPersons;
    }

    public void order(boolean asc)
    {
        Comparator<Person> comp = asc ? new ComparePerson() : Collections.reverseOrder(new ComparePerson());
        Collections.sort(this.listPersons, comp);
    }

    public void display()
    {
        for(Person p : this.listPersons)
        {
            System.out.println(p);
        }
    }

    /** Getters and Setters **/
}

Agora tentamos o seguinte:

import Java.util.ArrayList;
import Java.util.List;

public class App
{
    public static void main(String[] args)
    {
        Group g = new Group();
        List listPersons = new ArrayList<Person>();
        g.setListPersons(listPersons);

        Person p;

        p = new Person("A", "B");
        listPersons.add(p);

        p = new Person("C", "D");
        listPersons.add(p);

        /** you can add Person as many as you want **/

        g.display();

        g.order(true);
        g.display();

        g.order(false);
        g.display();
    }
}
1
Djahid Bekka

Isso pode funcionar?

Comparator mycomparator = 
    Collections.reverseOrder(Collections.reverseOrder());
1
xofon

Duas maneiras de fazer isso:

Collections.sort(myArray)

elementos fornecidos dentro do myArray implementa Comparable

Segundo

Collections.sort(myArray, new MyArrayElementComparator());

onde MyArrayElementComparator é Comparator para elementos dentro do myArray

1
mprabhat