Depois de um longo e tenebroso inverno ;-) voltei a postar aqui para vocês. Estou fazendo um curso que está me tomando um pouco de tempo, mas vamos lá.
Estive precisando de fazer umas ordenações de dados em java recentemente. Vejam que coisa legal esta Interface Comparator.
/*
Este programa ordena um Vector em ordem decrescente/crescente
Este programa ordena um Vector em ordem decrescente/crescente
utilizando a Interface Comparator
os dados de entrada são obtidos de um arquivo de texto cujos dados estão
os dados de entrada são obtidos de um arquivo de texto cujos dados estão
inseridos um por linha
*/
import java.util.Vector;
import java.util.Collections;
import java.util.Comparator;
import java.io.BufferedReader;
import java.io.FileReader;
import java.io.IOException;
import java.lang.NumberFormatException;
public class ExemploOrdenaVector {
public static void main(String[] args) {
// cria o vetor
Vector<Integer> v = new Vector<Integer>();
*/
import java.util.Vector;
import java.util.Collections;
import java.util.Comparator;
import java.io.BufferedReader;
import java.io.FileReader;
import java.io.IOException;
import java.lang.NumberFormatException;
public class ExemploOrdenaVector {
public static void main(String[] args) {
// cria o vetor
Vector<Integer> v = new Vector<Integer>();
// entrada de dados a partir do arquivo de texto
// utilizei a leitura com BufferedReader
// o loop preenche o vetor com os dados do arquivo
// utilizo método valueOf para converter a string em inteiro
String nomeArquivo = "dados.txt";
try {
BufferedReader in = new BufferedReader(new FileReader(nomeArquivo));
String linha = null;
while ((linha = in.readLine()) != null) {
try {
v.add(Integer.valueOf(linha));
} catch (NumberFormatException e1) {
// somente não insere
}
}
in.close();
}
catch (IOException e) {
System.out.println( "erro não tratado - somente indicação ");
}
System.out.println("Vetor não ordenado : " + v);
// Para ordenar um vetor devemos utilizar:
// static void sort(List list, Comparator c)
//
// como queremos na ordem inversa usamos Collections.reverseOrder()
Comparator comparator = Collections.reverseOrder();
Collections.sort(v,comparator);
System.out.println("Vetor ordenado (DESC) : " + v);
Collections.sort(v); // chamada igual sem o reverseOrder
System.out.println("Vetor ordenado (ASC) : " + v);
}
}
String nomeArquivo = "dados.txt";
try {
BufferedReader in = new BufferedReader(new FileReader(nomeArquivo));
String linha = null;
while ((linha = in.readLine()) != null) {
try {
v.add(Integer.valueOf(linha));
} catch (NumberFormatException e1) {
// somente não insere
}
}
in.close();
}
catch (IOException e) {
System.out.println( "erro não tratado - somente indicação ");
}
System.out.println("Vetor não ordenado : " + v);
// Para ordenar um vetor devemos utilizar:
// static void sort(List list, Comparator c)
//
// como queremos na ordem inversa usamos Collections.reverseOrder()
Comparator comparator = Collections.reverseOrder();
Collections.sort(v,comparator);
System.out.println("Vetor ordenado (DESC) : " + v);
Collections.sort(v); // chamada igual sem o reverseOrder
System.out.println("Vetor ordenado (ASC) : " + v);
}
}
Vamos ver este exemplo rodando:
Como esperado!!
O bacana deste código é que ele pode ser facilmente adaptado para qualquer tipo de dado. Vamos ver por exemplo para string. Temos que trocar somente 3 linhas:
- trocar o tipo do vetor para string
- trocar o arquivo de dados. só porque eu coloquei fixo no código. vejam que não muda nada no algoritmo de leitura...
- exceto a adição da linha ao vetor. agora não preciso fazer conversão
Fantástico, não é?
PS: para quem ficou curioso com o texto... É Lusíadas de Camões.
Nenhum comentário:
Postar um comentário