logo

Sortare în colecție

Putem sorta elementele din:

  1. Obiecte string
  2. Obiecte din clasa Wrapper
  3. Obiecte de clasă definite de utilizator
Colecții class oferă metode statice de sortare a elementelor unei colecții. Dacă elementele de colecție sunt de tip Set, putem folosi TreeSet. Cu toate acestea, nu putem sorta elementele List. Clasa Collections oferă metode de sortare a elementelor elementelor de tip Listă.

Metoda clasei Collections pentru sortarea elementelor List

public void sort (listă listă): este folosit pentru a sorta elementele List. Elementele listei trebuie să fie de tip Comparabil.

Notă: Clasa String și clasele Wrapper implementează interfața Comparable. Deci, dacă stocați obiectele claselor șir sau wrapper, va fi Comparabil.

Exemplu de sortare a obiectelor șir

 import java.util.*; class TestSort1{ public static void main(String args[]){ ArrayList al=new ArrayList(); al.add('Viru'); al.add('Saurav'); al.add('Mukesh'); al.add('Tahir'); Collections.sort(al); Iterator itr=al.iterator(); while(itr.hasNext()){ System.out.println(itr.next()); } } } 
Testează-l acum
 Mukesh Saurav Tahir Viru 

Exemplu de sortare a obiectelor șir în ordine inversă

 import java.util.*; class TestSort2{ public static void main(String args[]){ ArrayList al=new ArrayList(); al.add('Viru'); al.add('Saurav'); al.add('Mukesh'); al.add('Tahir'); Collections.sort(al,Collections.reverseOrder()); Iterator i=al.iterator(); while(i.hasNext()) { System.out.println(i.next()); } } } 
 Viru Tahir Saurav Mukesh 

Exemplu de sortare a obiectelor clasei Wrapper

 import java.util.*; class TestSort3{ public static void main(String args[]){ ArrayList al=new ArrayList(); al.add(Integer.valueOf(201)); al.add(Integer.valueOf(101)); al.add(230);//internally will be converted into objects as Integer.valueOf(230) Collections.sort(al); Iterator itr=al.iterator(); while(itr.hasNext()){ System.out.println(itr.next()); } } } 
 101 201 230 

Exemplu de sortare a obiectelor de clasă definite de utilizator

 import java.util.*; class Student implements Comparable { public String name; public Student(String name) { this.name = name; } public int compareTo(Student person) { return name.compareTo(person.name); } } public class TestSort4 { public static void main(String[] args) { ArrayList al=new ArrayList(); al.add(new Student('Viru')); al.add(new Student('Saurav')); al.add(new Student('Mukesh')); al.add(new Student('Tahir')); Collections.sort(al); for (Student s : al) { System.out.println(s.name); } } } 
 Mukesh Saurav Tahir Viru