|
|||||||
|
|
|
![]() |
|
|
Strumenti |
|
|
#1 |
|
Senior Member
Iscritto dal: Jan 2001
Città: Villanova di Guidonia (RM)
Messaggi: 1079
|
[C] Scomposizione in fattori primi
Ciao a tutti!
Devo scrivere un programma dove dato un numero n mi stampi la sua scomposizione in fattori primi. Non riesco a pensare ad un algoritmo funzionante. Voi che mi consigliate? |
|
|
|
|
|
#2 |
|
Senior Member
Iscritto dal: Jan 2001
Città: Villanova di Guidonia (RM)
Messaggi: 1079
|
Non fa niente.. ho trovato in rete il codice Java. Stavo impazzendo per farlo (anche se era semplice), cmq la mia idea c'andava vicino, perché io facevo ripetutamente la divisione per 2 però poi non sapevo gestire i casi successivi, cioè quando il numero non era più divisibile per 2. Grazie
|
|
|
|
|
|
#3 |
|
Moderatore
Iscritto dal: Nov 2003
Messaggi: 16213
|
In effetti... basta provare tutti i possibili divisori, e continuare a dividere finché si può.
Credo che la struttura dati più adatta sia una coda.
__________________
Ubuntu è un'antica parola africana che significa "non so configurare Debian" Scienza e tecnica: Matematica - Fisica - Chimica - Informatica - Software scientifico - Consulti medici REGOLAMENTO DarthMaul = Asus FX505 Ryzen 7 3700U 8GB GeForce GTX 1650 Win10 + Ubuntu |
|
|
|
|
|
#4 |
|
Senior Member
Iscritto dal: Jan 2001
Città: Villanova di Guidonia (RM)
Messaggi: 1079
|
Grazie Ziosilvio però alle liste, pile, code e strutture dati varie ancora non ci siamo arrivati (dobbiamo fare ancora gli array). Siamo proprio a un livello primordiale, quindi il programma andava fatto appunto a questo livello.
|
|
|
|
|
|
#5 |
|
Moderatore
Iscritto dal: Nov 2003
Messaggi: 16213
|
Uhm... ripensandoci... puoi effettuare l'output a schermo "al volo", tanto deve venir fuori una cosa del tipo: "n = p1^e1 + p2^e2 + ... + pk^ek".
Praticamente: - cominci stampando "n = "; - trovi il primo fattore p1, che (se ci pensi un attimo) deve essere primo; - dividi n per p1 tante volte finché puoi, tenendo il conto; - stampi "p1^e1"; - se non ci sono altri fattori hai finito; - se ce ne sono, osservato che il primo che trovi deve essere primo, fai come prima; - stampi " + p2^e2"; e così via.
__________________
Ubuntu è un'antica parola africana che significa "non so configurare Debian" Scienza e tecnica: Matematica - Fisica - Chimica - Informatica - Software scientifico - Consulti medici REGOLAMENTO DarthMaul = Asus FX505 Ryzen 7 3700U 8GB GeForce GTX 1650 Win10 + Ubuntu |
|
|
|
|
|
#6 |
|
Senior Member
Iscritto dal: Jan 2001
Città: Villanova di Guidonia (RM)
Messaggi: 1079
|
Ok ma il primo fattore in base a quale criterio lo trovo? Cioè se n=18 ne ho tanti di numeri primi da trovare tra 1 e 18.
|
|
|
|
|
|
#7 |
|
Senior Member
Iscritto dal: Apr 2000
Città: Vicino a Montecatini(Pistoia) Moto:Kawasaki Ninja ZX-9R Scudetti: 29
Messaggi: 53971
|
Inizi da 2 e sali su fino alla radice quadrata di n
Continui a dividere fino a quando il resto della divisione è uguale a 0... |
|
|
|
|
|
#8 | |
|
Bannato
Iscritto dal: Feb 2003
Messaggi: 947
|
Quote:
|
|
|
|
|
|
|
#9 |
|
Senior Member
Iscritto dal: Jan 2001
Città: Villanova di Guidonia (RM)
Messaggi: 1079
|
Grazie ma perché fino alla radice quadrata di n e non fino a n?
|
|
|
|
|
|
#10 | |
|
Senior Member
Iscritto dal: Apr 2000
Città: Vicino a Montecatini(Pistoia) Moto:Kawasaki Ninja ZX-9R Scudetti: 29
Messaggi: 53971
|
Quote:
Quindi per massimizzare k devo minimizzare j... Il minimo divisore diverso da 1 è 2... Quindi k <= n / 2... Se non trovi fattori minori o uguali ad n / 2 allora n è primo... Ultima modifica di cionci : 20-10-2005 alle 13:06. |
|
|
|
|
|
|
#11 |
|
Moderatore
Iscritto dal: Nov 2003
Messaggi: 16213
|
Vero!
Il controllo fino a sqrt(n) va bene per determinare la primalità di un numero, perché se un numero n è composto, allora ha un divisore primo p tale che p^2 <= n. Per determinare la decomposizione in fattori primi di un numero, la cosa è diversa (e NP-completa)... ... a meno, naturalmente, di non aggiornare volta per volta il numero da fattorizzare... ma qui dovrei provare a scrivere del codice...
__________________
Ubuntu è un'antica parola africana che significa "non so configurare Debian" Scienza e tecnica: Matematica - Fisica - Chimica - Informatica - Software scientifico - Consulti medici REGOLAMENTO DarthMaul = Asus FX505 Ryzen 7 3700U 8GB GeForce GTX 1650 Win10 + Ubuntu |
|
|
|
|
|
#12 |
|
Senior Member
Iscritto dal: Jan 2001
Città: Villanova di Guidonia (RM)
Messaggi: 1079
|
Ok grazie ho capito
|
|
|
|
|
| Strumenti | |
|
|
Tutti gli orari sono GMT +1. Ora sono le: 03:01.



















