Come verificare se due stringhe sono anagrammi l'una dell'altra

Come verificare se due stringhe sono anagrammi l'una dell'altra

Un anagramma è una stringa formata riordinando le lettere di una stringa diversa. Controllare se due stringhe sono anagrammi l'una dell'altra potrebbe sembrare difficile, ma è solo un po' complicato e ingannevolmente semplice. In questo articolo imparerai come verificare se due stringhe sono anagrammi l'una dell'altra usando C++, Python e JavaScript.





Dichiarazione problema

Ti vengono date due stringhe s1 e s2, devi verificare se le due stringhe sono anagrammi l'una dell'altra o meno.





Esempio 1 : Sia s1 = 'creativo' e s2 = 'reattivo'.





Poiché la seconda stringa può essere formata riordinando le lettere della prima stringa e viceversa, quindi le due stringhe sono anagrammi l'una dell'altra.

Esempio 2 : Sia s1 = 'Peter Piper raccolse un bacetto di peperoni sott'aceto' e s2 = 'Un bacetto di peperoni sott'aceto raccolse Peter Piper'.



Poiché la seconda stringa non può essere formata riordinando le lettere della prima stringa e viceversa, quindi le due stringhe non sono anagrammi l'una dell'altra.

Processo per verificare se due stringhe sono anagrammi l'una dell'altra

Puoi seguire l'approccio seguente per verificare se le due stringhe sono anagrammi l'una dell'altra:





  1. Confronta la lunghezza di entrambe le stringhe.
  2. Se la lunghezza di entrambe le stringhe non è la stessa, significa che non possono essere anagrammi l'una dell'altra. Quindi, restituire false.
  3. Se la lunghezza di entrambe le stringhe è la stessa, procedi ulteriormente.
  4. Ordina entrambe le stringhe.
  5. Confronta entrambe le stringhe ordinate.
  6. Se entrambe le stringhe ordinate sono uguali, significa che sono anagrammi l'una dell'altra. Quindi, ritorna vero.
  7. Se entrambe le stringhe ordinate sono diverse, significa che non sono anagrammi l'una dell'altra. Quindi, restituire false.

Imparentato: Come verificare se una stringa è un palindromo

Programma C++ per verificare se due stringhe sono anagrammi l'una dell'altra

Di seguito è riportato il programma C++ per verificare se due stringhe sono anagrammi l'una dell'altra o meno:





#include
using namespace std;
bool checkAnagrams(string s1, string s2)
{
int size1 = s1.length();
int size2 = s2.length();
// If the length of both strings are not the same,
// it means they can't be anagrams of each other.
// Thus, return false.
if (size1 != size2)
{
return false;
}
sort(s1.begin(), s1.end());
sort(s2.begin(), s2.end());
for (int i = 0; i {
if (s1[i] != s2[i])
{
return false;
}
}
return true;
}
int main()
{
string s1 = 'listen';
string s2 = 'silent';
cout << 'String 1: ' << s1 << endl;
cout << 'String 2: ' << s2 << endl;
if(checkAnagrams(s1, s2))
{
cout << 'Yes, the two strings are anagrams of each other' << endl;
}
else
{
cout << 'No, the two strings are not anagrams of each other' << endl;
}
string s3 = 'Welcome to MUO';
string s4 = 'MUO to Welcome';
cout << 'String 3: ' << s3 << endl;
cout << 'String 4: ' << s4 << endl;
if(checkAnagrams(s3, s4))
{
cout << 'Yes, the two strings are anagrams of each other' << endl;
}
else
{
cout << 'No, the two strings are not anagrams of each other' << endl;
}
string s5 = 'Peter Piper picked a peck of pickled peppers';
string s6 = 'A peck of pickled peppers Peter Piper picked';
cout << 'String 5: ' << s5 << endl;
cout << 'String 6: ' << s6 << endl;
if(checkAnagrams(s5, s6))
{
cout << 'Yes, the two strings are anagrams of each other' << endl;
}
else
{
cout << 'No, the two strings are not anagrams of each other' << endl;
}
string s7 = 'She sells seashells by the seashore';
string s8 = 'seashells by the seashore';
cout << 'String 7: ' << s7 << endl;
cout << 'String 8: ' << s8 << endl;
if(checkAnagrams(s7, s8))
{
cout << 'Yes, the two strings are anagrams of each other' << endl;
}
else
{
cout << 'No, the two strings are not anagrams of each other' << endl;
}
string s9 = 'creative';
string s10 = 'reactive';
cout << 'String 9: ' << s9 << endl;
cout << 'String 10: ' << s10 << endl;
if(checkAnagrams(s9, s10))
{
cout << 'Yes, the two strings are anagrams of each other' << endl;
}
else
{
cout << 'No, the two strings are not anagrams of each other' << endl;
}
return 0;
}

Produzione:

String 1: listen
String 2: silent
Yes, the two strings are anagrams of each other
String 3: Welcome to MUO
String 4: MUO to Welcome
Yes, the two strings are anagrams of each other
String 5: Peter Piper picked a peck of pickled peppers
String 6: A peck of pickled peppers Peter Piper picked
No, the two strings are not anagrams of each other
String 7: She sells seashells by the seashore
String 8: seashells by the seashore
No, the two strings are not anagrams of each other
String 9: creative
String 10: reactive
Yes, the two strings are anagrams of each other

Correlati: Come contare le occorrenze di un dato carattere in una stringa

Programma Python per verificare se due stringhe sono anagrammi l'una dell'altra

Di seguito è riportato il programma Python per verificare se due stringhe sono anagrammi l'una dell'altra o meno:

def checkAnagrams(s1, s2):
size1 = len(s1)
size2 = len(s2)
# If the length of both strings are not the same,
# it means they can't be anagrams of each other.
# Thus, return false.
if size1 != size2:
return 0
s1 = sorted(s1)
s2 = sorted(s2)
for i in range(0, size1):
if s1[i] != s2[i]:
return False
return True

s1 = 'listen'
s2 = 'silent'
print('String 1: ', s1)
print('String 2: ', s2)
if(checkAnagrams(s1, s2)):
print('Yes, the two strings are anagrams of each other')
else:
print('No, the two strings are not anagrams of each other')
s3 = 'Welcome to MUO'
s4 = 'MUO to Welcome'
print('String 3: ', s3)
print('String 4: ', s4)
if(checkAnagrams(s3, s4)):
print('Yes, the two strings are anagrams of each other')
else:
print('No, the two strings are not anagrams of each other')
s5 = 'Peter Piper picked a peck of pickled peppers'
s6 = 'A peck of pickled peppers Peter Piper picked'
print('String 5: ', s5)
print('String 6: ', s6)
if(checkAnagrams(s5, s6)):
print('Yes, the two strings are anagrams of each other')
else:
print('No, the two strings are not anagrams of each other')
s7 = 'She sells seashells by the seashore'
s8 = 'seashells by the seashore'
print('String 7: ', s7)
print('String 8: ', s8)
if(checkAnagrams(s7, s8)):
print('Yes, the two strings are anagrams of each other')
else:
print('No, the two strings are not anagrams of each other')
s9 = 'creative'
s10 = 'reactive'
print('String 9: ', s9)
print('String 10: ', s10)
if(checkAnagrams(s9, s10)):
print('Yes, the two strings are anagrams of each other')
else:
print('No, the two strings are not anagrams of each other')

Produzione:

String 1: listen
String 2: silent
Yes, the two strings are anagrams of each other
String 3: Welcome to MUO
String 4: MUO to Welcome
Yes, the two strings are anagrams of each other
String 5: Peter Piper picked a peck of pickled peppers
String 6: A peck of pickled peppers Peter Piper picked
No, the two strings are not anagrams of each other
String 7: She sells seashells by the seashore
String 8: seashells by the seashore
No, the two strings are not anagrams of each other
String 9: creative
String 10: reactive
Yes, the two strings are anagrams of each other

Correlati: Come trovare vocali, consonanti, cifre e caratteri speciali in una stringa

Controlla se due stringhe sono anagrammi l'una dell'altra in JavaScript

Di seguito è riportato il programma JavaScript per verificare se due stringhe sono anagrammi l'una dell'altra o meno:

function checkAnagrams(s1, s2) {
let size1 = s1.length;
let size2 = s2.length;
// If the length of both strings are not the same,
// it means they can't be anagrams of each other.
// Thus, return false.
if (size1 != size2)
{
return false;
}
s1.sort();
s2.sort();
for (let i = 0; i {
if (s1[i] != s2[i])
{
return false;
}
}
return true;
}

var s1 = 'listen';
var s2 = 'silent';
document.write('String 1: ' + s1 + '
');
document.write('String 2: ' + s2 + '
');
if(checkAnagrams(s1.split(''), s2.split(''))) {
document.write('Yes, the two strings are anagrams of each other' + '
');
} else {
document.write('No, the two strings are not anagrams of each other' + '
');
}
var s3 = 'Welcome to MUO';
var s4 = 'MUO to Welcome';
document.write('String 3: ' + s3 + '
');
document.write('String 4: ' + s4 + '
');
if(checkAnagrams(s3.split(''), s4.split(''))) {
document.write('Yes, the two strings are anagrams of each other' + '
');
} else {
document.write('No, the two strings are not anagrams of each other' + '
');
}
var s5 = 'Peter Piper picked a peck of pickled peppers';
var s6 = 'A peck of pickled peppers Peter Piper picked';
document.write('String 5: ' + s5 + '
');
document.write('String 6: ' + s6 + '
');
if(checkAnagrams(s5.split(''), s6.split(''))) {
document.write('Yes, the two strings are anagrams of each other' + '
');
} else {
document.write('No, the two strings are not anagrams of each other' + '
');
}
var s7 = 'She sells seashells by the seashore';
var s8 = 'seashells by the seashore';
document.write('String 7: ' + s7 + '
');
document.write('String 8: ' + s8 + '
');
if(checkAnagrams(s7.split(''), s8.split(''))) {
document.write('Yes, the two strings are anagrams of each other' + '
');
} else {
document.write('No, the two strings are not anagrams of each other' + '
');
}
var s9 = 'creative';
var s10 = 'reactive';
document.write('String 9: ' + s9 + '
');
document.write('String 10: ' + s10 + '
');
if(checkAnagrams(s9.split(''), s10.split(''))) {
document.write('Yes, the two strings are anagrams of each other' + '
');
} else {
document.write('No, the two strings are not anagrams of each other' + '
');
}

Produzione:

String 1: listen
String 2: silent
Yes, the two strings are anagrams of each other
String 3: Welcome to MUO
String 4: MUO to Welcome
Yes, the two strings are anagrams of each other
String 5: Peter Piper picked a peck of pickled peppers
String 6: A peck of pickled peppers Peter Piper picked
No, the two strings are not anagrams of each other
String 7: She sells seashells by the seashore
String 8: seashells by the seashore
No, the two strings are not anagrams of each other
String 9: creative
String 10: reactive
Yes, the two strings are anagrams of each other

Imparentato: Come si trova il valore ASCII di un carattere?

Usa le risorse giuste per imparare a programmare

Se stai cercando di consolidare le tue capacità di programmazione, è importante apprendere nuovi concetti e dedicare del tempo a utilizzarli. Un modo per farlo è con le app di programmazione, che ti aiuteranno ad apprendere diversi concetti di programmazione divertendoti allo stesso tempo.

Condividere Condividere Tweet E-mail 8 app per aiutarti a imparare a programmare per la Giornata internazionale dei programmatori

Vuoi rispolverare le tue abilità di programmazione? Queste app e questi siti Web ti aiuteranno a imparare a programmare secondo i tuoi ritmi.

guarda youtube allo stesso tempo
Leggi Avanti Argomenti correlati
  • Programmazione
  • JavaScript
  • Pitone
  • C Programmazione
Circa l'autore Yuvraj Chandra(60 articoli pubblicati)

Yuvraj è uno studente universitario di Informatica presso l'Università di Delhi, in India. È appassionato di sviluppo Web Full Stack. Quando non scrive, esplora la profondità di diverse tecnologie.

Altro da Yuvraj Chandra

Iscriviti alla nostra Newsletter

Iscriviti alla nostra newsletter per suggerimenti tecnici, recensioni, ebook gratuiti e offerte esclusive!

Clicca qui per iscriverti