|
|||||||
|
|
|
![]() |
|
|
Strumenti |
|
|
#1 |
|
Member
Iscritto dal: Nov 2007
Città: Messina
Messaggi: 45
|
[Algoritmo] Stabilire se una parola viene alfabeticamente prima di un'altra
Ciao a tutti.
Ho bisogno di un piccolo aiuto nella risoluzione di un algoritmo affrontato all'università e che mi sta lasciando qualche dubbio. Ritengo la sezione più adatta per chiedere sia questa, spero di non aver sbagliato. Ma torniamo al tema centrale. "Stabilire se una parola viene alfabeticamente prima di un’altra" Questo sopra è l'algoritmo che io credo in una sua prima parte vada risolto così: - Definisco l'alfabeto dicendo che A<B<C<...<Z; - Leggi parola1; - Leggi parola2; - Chiama la prima lettera della parola1 a e la prima lettera della parola2 b - Confronta a con b: se a < b allora la parola1 viene prima della parola2; se a > b allora la parola2 viene prima della parola1; ora però se le lettere son uguali devo confrontare le altre lettere...e come faccio a definire il confronto tra le altre lettere senza scrivere mille righe e soprattutto è possibile questo confronto? |
|
|
|
|
|
#2 |
|
Senior Member
Iscritto dal: Oct 2007
Città: Padova
Messaggi: 4131
|
Il confronto tra due lettere viene eseguito in un ciclo che si ripete finchè non vengono trovate due lettere tra loro diverse.
__________________
As long as you are basically literate in programming, you should be able to express any logical relationship you understand. If you don’t understand a logical relationship, you can use the attempt to program it as a means to learn about it. (Chris Crawford) |
|
|
|
|
|
#3 |
|
Senior Member
Iscritto dal: Dec 2003
Messaggi: 4907
|
Ecco una semplice, chiara e concisa funzione ricorsiva in C:
Codice:
int
____( char
*_, char
*__, int
___){ return
_[___] =='\0'
&&__ [___] =='\0'
?0:_ [___]
>__ [___]
?1:_ [___]
<__ [___]
?2:____ (_,__,
++___)
;}
![]() Edit: Resa più chiara e concisa. Ultima modifica di ||ElChE||88 : 24-09-2008 alle 15:47. |
|
|
|
|
|
#4 |
|
Senior Member
Iscritto dal: Dec 2003
Messaggi: 4907
|
|
|
|
|
|
|
#5 | |
|
Member
Iscritto dal: Jul 2008
Città: Nel mio studio
Messaggi: 168
|
Quote:
__________________
Since Rocco Siffredi, the saying "pain in the ass" got a total new meaning |
|
|
|
|
|
|
#6 | |
|
Senior Member
Iscritto dal: Aug 2003
Città: Barletta (BA)
Messaggi: 939
|
Quote:
__________________
In a world without fences, who needs Gates? Power by: Fedora 8 - Mac OS X 10.4.11 |
|
|
|
|
|
|
#7 |
|
Senior Member
Iscritto dal: Jul 2002
Città: Reggio Calabria -> London
Messaggi: 12112
|
Codice:
def value(word):
value = 0
for c in word.lower():
value = value + ord(c)
return value
def maggiore(word1, word2):
return value(word1) < value(word2)
print maggiore('ciao', 'ciaa')
print 'ciao'.lower() < 'ciaa'.lower()
Comunque è un non-sense dato che l'ultima riga di codice fa esattamente la stessa cosa delle due funzioni che ho implementato.
__________________
|
|
|
|
|
|
#8 | |
|
Senior Member
Iscritto dal: Dec 2003
Messaggi: 4907
|
Quote:
|
|
|
|
|
|
|
#9 | |
|
Senior Member
Iscritto dal: Jul 2002
Città: Reggio Calabria -> London
Messaggi: 12112
|
Quote:
Comunque la soluzione migliore è ovviamente usare l'operatore di confronto < che da sempre il risultato corretto in una sola riga di codice
__________________
|
|
|
|
|
|
|
#10 |
|
Senior Member
Iscritto dal: Dec 2003
Messaggi: 4907
|
|
|
|
|
|
|
#11 | |
|
Senior Member
Iscritto dal: Nov 2005
Messaggi: 2776
|
Quote:
|
|
|
|
|
|
|
#12 |
|
Senior Member
Iscritto dal: Jul 2002
Città: Reggio Calabria -> London
Messaggi: 12112
|
e vabbè...
che 2 palle.. basta assegnare un peso ad ogni carattere Se sapevo scrivevo solo print 'cazz' < 'cip' anzichè fare tutto l'algoritmo
__________________
|
|
|
|
|
| Strumenti | |
|
|
Tutti gli orari sono GMT +1. Ora sono le: 06:31.






















