logo

Ordem Lexicográfica Java

O termo ordem lexicográfica é um termo matemático conhecido pelos nomes: ordem lexical, produto lexicográfico(al), ordem alfabética ou ordem de dicionário.

Esta seção cobrirá o tópico ordem lexicográfica, sua definição e outras informações detalhadas. Depois disso, aprenderemos como usar o conceito de ordem lexicográfica no Linguagem de programação Java .

Definindo Ordem Lexicográfica

Ordem lexicográfica ou lexicográfica em matemática é uma generalização da sequência alfabética dos dicionários às sequências dos símbolos ordenados ou elementos de uma lista totalmente ordenada. O termo ordem lexicográfica é motivado pela palavra 'léxico'. Léxico é o conjunto de palavras usadas em algumas das outras línguas e possui uma ordem convencional. Assim, a ordem lexicográfica é uma forma de formalizar a ordem das palavras onde a ordem dos símbolos subjacentes é dada.

Na programação, a ordem lexicográfica é popularmente conhecida como Ordem do dicionário e é usado para classificar uma matriz de strings, comparar duas strings ou classificar elementos da matriz. Torna-se muito fácil classificar os elementos lexicamente. É porque a ordem lexicográfica possui diversas variantes e generalizações nas quais:

  • Uma variante é aplicável às sequências de comprimentos diferentes, pois antes de considerar os elementos particulares, os comprimentos das sequências são comparados.
  • A segunda variante é usada para ordenar subconjuntos de um determinado conjunto finito. Isso é feito atribuindo uma ordem total ao conjunto finito. Em seguida, converte subconjuntos em sequências crescentes às quais a ordem lexicográfica é aplicada.
  • A generalização refere-se à sequência do produto cartesiano de conjuntos parcialmente ordenados, e tal sequência é uma ordem total, se e somente se cada fator do produto cartesiano estiver totalmente ordenado.

Compreendendo a noção formal de ordem lexicográfica

  • Para compreender a noção formal de ordem lexicográfica:
  • Começa com um conjunto finito A, conhecido como alfabeto e é completamente sequenciado. Significa ainda que para aeb (quaisquer dois símbolos que sejam diferentes e não iguais) em A, ou um
  • Aqui, as palavras de A são a sequência finita de símbolos de A e incluem palavras de comprimento 1 contendo um único símbolo, palavras de comprimento 2 com dois símbolos, e para palavras de comprimento três, é 3 e assim por diante. No que diz respeito, também inclui a sequência vazia? não contendo nenhum símbolo. Assim, a ordem lexicográfica para o conjunto finito A pode ser descrita como:
  • Suponha que, para dois mundos diferentes do mesmo comprimento, a=a1a2…ake b = b1b2…bké dada. Aqui, a ordem de duas palavras depende da ordem alfabética dos símbolos em primeiro lugar i onde duas palavras variam ao contar desde o início das palavras, ou seja, satisfazendo a condição a eu i dentro da ordem do alfabeto A.
  • Se duas palavras tiverem comprimento variado, a ordem lexicográfica usual preenche a palavra com comprimento mais curto com espaços em branco no final até que ambas as palavras tenham o mesmo comprimento, e então as palavras são comparadas.

Implementando Lexicográfico em Java

Conforme discutido acima, essa ordem lexicográfica pode ser usada para comparar duas strings ou para classificar os elementos. Aqui, discutiremos ambos os métodos e implementaremos cada um.

Classificando elementos em ordem lexicográfica

Organizar as palavras em ordem é conhecido como ordem lexicográfica ou também conhecido como Ordem do dicionário . Isso significa que, ao aplicar a ordem lexicográfica, as palavras são ordenadas alfabeticamente de acordo com seus alfabetos componentes. Para classificar uma matriz de strings em ordem lexicográfica, temos os dois métodos a seguir:

Método 1: aplicando qualquer método de classificação

Abaixo está o código de exemplo fornecido que nos permitirá entender como podemos realizar a classificação dos elementos na ordem lexicográfica:

 public class Main { public static void main(String[] args) { String[] name = { &apos;John&apos;,&apos;Remo&apos;,&apos;Mixy&apos;,&apos;Julie&apos;,&apos;Ronny&apos;}; int n = 5; System.out.println(&apos;Before Sorting&apos;); for(int i = 0; i <n; i++) { system.out.println(name[i]); } for(int i="0;" < n-1; ++i) for (int j="i" + 1; 0) string temp="name[i];" name[i]="name[j];" name[j]="temp;" system.out.println('
after performing lexicographical order: '); n; pre> <p> <strong>Code Explanation:</strong> </p> <p>In the above code, we have created a class Main within which the main () method is created.</p> <ul> <li>A string has been initialized, holding some values to it, and each word will get printed as per for loop.</li> <li>Then, we have implemented the main logic within another for loop with the help of which we can form the lexicographical order of the words given.</li> <li>Finally, via for loop, the arranged words are printed on the screen.</li> </ul> <p> <strong>On executing the above example code, we got the following output:</strong> </p> <img src="//techcodeview.com/img/java-tutorial/62/lexicographical-order-java.webp" alt="Lexicographical Order Java"> <p>From the output, we can analyze that the given sequence of the words was not in alphabetical order but after applying the lexicographical order code, we can see that every word is sequenced now in alphabetical order.</p> <p> <strong>Method 2: Applying sort () function</strong> </p> <p>The sort () method is available in the Arrays class within the util package.</p> <p>Below is the example code given that will let us understand that how we can perform sorting on elements in Lexicographical order:</p> <pre> import java.io.*; import java.util.Arrays; class Main { public static void printArray(String str[]) { for (String string : str) System.out.print(string + &apos; &apos;); System.out.println(); } public static void main(String[] args) { String arr[] = {&apos;John&apos;,&apos;Harry&apos;,&apos;Emlie&apos;,&apos;Ronny&apos;,&apos;Julie&apos;,&apos;Mary&apos; }; Arrays.sort(arr,String.CASE_INSENSITIVE_ORDER); printArray(arr); } } </pre> <p> <strong>On executing the above output, we got the below-shown output:</strong> </p> <img src="//techcodeview.com/img/java-tutorial/62/lexicographical-order-java-2.webp" alt="Lexicographical Order Java"> <h3>Comparing two strings using Lexicographical order in Java</h3> <p>For comparing two strings using Lexicographical order, we have the following two methods:</p> <p> <strong>Using compareTo () method</strong> </p> <p>Let&apos;s begin one by one:</p> <p> <strong>Using compareTo () method</strong> </p> <p>Below is an example implementation by which we can compare to strings lexicographically:</p> <pre> import java.lang.*; public class StringExample { public static void main(String[] args) { String str1 = &apos;String&apos;, str2 = &apos;Comparison&apos;; int get_val = str1.compareTo(str2); if (get_val <0) { system.out.println('str1 is greater than str2'); } else if (get_val="=" 0) equal to less < pre> <p> <strong>Code Explanation:</strong> </p> <ul> <li>We have created a class StringExample where we have implemented the main () method.</li> <li>We have initialized two strings, i.e., str1 and str2.</li> <li>Next, using the compareTo () method, we have compared the strings str1 and str2.</li> <li>After it, if the get_val value is found less than 0, it means str1 is greater than str2.</li> <li>Else if the get_val value is equal to 0, it means both str1 and str2 strings are equal.</li> <li>Else, both the strings str1 is less than str2.</li> </ul> <p> <strong>Output:</strong> </p> <img src="//techcodeview.com/img/java-tutorial/62/lexicographical-order-java-3.webp" alt="Lexicographical Order Java"> <p> <strong>By creating a user-defined function</strong> </p> <p>Below we have created a user-defined function using which we can compare two strings lexicographically. The code is as follows:</p> <pre> public class StringExample { public static void main(String[] args) { String firstString = &apos;Red&apos;; String secondString = &apos;Red&apos;; String thirdString = &apos;Green&apos;; String fourthString = &apos;Yellow&apos;; String fifthString = &apos;REdGreen&apos;; System.out.println(&apos;Comparing two strings lexicographically by user defined function&apos;); System.out.print(&apos;
Compairing firstString (&apos;+firstString+&apos;) to the secondString (&apos;+secondString+&apos;) returns: &apos;); System.out.println(compareString(firstString, secondString)); System.out.print(&apos;
Compairing secondString (&apos;+secondString+&apos;) to the thirdString (&apos;+thirdString+&apos;) returns: &apos;); System.out.println(compareString(secondString, thirdString)); System.out.print(&apos;
Compairing thirdString (&apos;+thirdString+&apos;) to the fourthString (&apos;+fourthString+&apos;) returns: &apos;); System.out.println(compareString(thirdString, fourthString)); System.out.print(&apos;
Compairing fourthString (&apos;+fourthString+&apos;) to the firstString (&apos;+firstString+&apos;) returns: &apos;); System.out.println(compareString(fourthString, firstString)); System.out.print(&apos;
Compairing firstString (&apos;+firstString+&apos;) to the fifthString (&apos;+fifthString+&apos;) returns: &apos;); System.out.println(compareString(firstString, fifthString)); } public static int compareString(String str, String argString) { int lim= Math.min(str.length(), argString.length()); int k=0; while(k<lim) { if(str.charat(k)!="argString.charAt(k))" return (int) str.charat(k)- argstring.charat(k); } k++; str.length() - argstring.length(); < pre> <p> <strong>Output:</strong> </p> <img src="//techcodeview.com/img/java-tutorial/62/lexicographical-order-java-4.webp" alt="Lexicographical Order Java"> <p> <strong>Code Explanation:</strong> </p> <ul> <li>We have created a Java class where we have initialized five strings.</li> <li>Next, we have compared the first string with the second string, the second to the third-string, and so on..</li> <li>For making the comparison, we have created a user-defined function compareString () whereby comparing the length and each character of the strings, and we got the results.</li> </ul> <p>Therefore, in this way, we can make use of the lexicographical order in Java for performing such tasks.</p> <hr></lim)></pre></0)></pre></n;>

Ao executar a saída acima, obtivemos a saída mostrada abaixo:

Ordem Lexicográfica Java

Comparando duas strings usando ordem lexicográfica em Java

Para comparar duas strings usando ordem lexicográfica, temos os dois métodos a seguir:

Usando o método compareTo()

Vamos começar um por um:

Usando o método compareTo()

Abaixo está um exemplo de implementação pelo qual podemos comparar lexicograficamente com strings:

 import java.lang.*; public class StringExample { public static void main(String[] args) { String str1 = &apos;String&apos;, str2 = &apos;Comparison&apos;; int get_val = str1.compareTo(str2); if (get_val <0) { system.out.println(\'str1 is greater than str2\'); } else if (get_val="=" 0) equal to less < pre> <p> <strong>Code Explanation:</strong> </p> <ul> <li>We have created a class StringExample where we have implemented the main () method.</li> <li>We have initialized two strings, i.e., str1 and str2.</li> <li>Next, using the compareTo () method, we have compared the strings str1 and str2.</li> <li>After it, if the get_val value is found less than 0, it means str1 is greater than str2.</li> <li>Else if the get_val value is equal to 0, it means both str1 and str2 strings are equal.</li> <li>Else, both the strings str1 is less than str2.</li> </ul> <p> <strong>Output:</strong> </p> <img src="//techcodeview.com/img/java-tutorial/62/lexicographical-order-java-3.webp" alt="Lexicographical Order Java"> <p> <strong>By creating a user-defined function</strong> </p> <p>Below we have created a user-defined function using which we can compare two strings lexicographically. The code is as follows:</p> <pre> public class StringExample { public static void main(String[] args) { String firstString = &apos;Red&apos;; String secondString = &apos;Red&apos;; String thirdString = &apos;Green&apos;; String fourthString = &apos;Yellow&apos;; String fifthString = &apos;REdGreen&apos;; System.out.println(&apos;Comparing two strings lexicographically by user defined function&apos;); System.out.print(&apos;
Compairing firstString (&apos;+firstString+&apos;) to the secondString (&apos;+secondString+&apos;) returns: &apos;); System.out.println(compareString(firstString, secondString)); System.out.print(&apos;
Compairing secondString (&apos;+secondString+&apos;) to the thirdString (&apos;+thirdString+&apos;) returns: &apos;); System.out.println(compareString(secondString, thirdString)); System.out.print(&apos;
Compairing thirdString (&apos;+thirdString+&apos;) to the fourthString (&apos;+fourthString+&apos;) returns: &apos;); System.out.println(compareString(thirdString, fourthString)); System.out.print(&apos;
Compairing fourthString (&apos;+fourthString+&apos;) to the firstString (&apos;+firstString+&apos;) returns: &apos;); System.out.println(compareString(fourthString, firstString)); System.out.print(&apos;
Compairing firstString (&apos;+firstString+&apos;) to the fifthString (&apos;+fifthString+&apos;) returns: &apos;); System.out.println(compareString(firstString, fifthString)); } public static int compareString(String str, String argString) { int lim= Math.min(str.length(), argString.length()); int k=0; while(k<lim) { if(str.charat(k)!="argString.charAt(k))" return (int) str.charat(k)- argstring.charat(k); } k++; str.length() - argstring.length(); < pre> <p> <strong>Output:</strong> </p> <img src="//techcodeview.com/img/java-tutorial/62/lexicographical-order-java-4.webp" alt="Lexicographical Order Java"> <p> <strong>Code Explanation:</strong> </p> <ul> <li>We have created a Java class where we have initialized five strings.</li> <li>Next, we have compared the first string with the second string, the second to the third-string, and so on..</li> <li>For making the comparison, we have created a user-defined function compareString () whereby comparing the length and each character of the strings, and we got the results.</li> </ul> <p>Therefore, in this way, we can make use of the lexicographical order in Java for performing such tasks.</p> <hr></lim)></pre></0)>