Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Roborock Qrevo Curv 2 Flow: ora lava con un rullo
Roborock Qrevo Curv 2 Flow: ora lava con un rullo
Qrevo Curv 2 Flow è l'ultima novità di casa Roborock per la pulizia di casa: un robot completo, forte di un sistema di lavaggio dei pavimenti basato su rullo che si estende a seguire il profilo delle pareti abbinato ad un potente motore di aspirazione con doppia spazzola laterale
Alpine A290 alla prova: un'auto bella che ti fa innamorare, con qualche limite
Alpine A290 alla prova: un'auto bella che ti fa innamorare, con qualche limite
Abbiamo guidato per diversi giorni la Alpine A290, la prima elettrica del nuovo corso della marca. Non è solo una Renault 5 sotto steroidi, ha una sua identità e vuole farsi guidare
Recensione HONOR Magic 8 Lite: lo smartphone indistruttibile e instancabile
Recensione HONOR Magic 8 Lite: lo smartphone indistruttibile e instancabile
Abbiamo provato a fondo il nuovo Magic 8 Lite di HONOR, e per farlo siamo volati fino a Marrakech , dove abbiamo testato la resistenza di questo smartphone in ogni condizione possibile ed immaginabile. Il risultato? Uno smartphone praticamente indistruttibile e con un'autonomia davvero ottima. Ma c'è molto altro da sapere su Magic 8 Lite, ve lo raccontiamo in questa recensione completa.
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 19-10-2005, 19:31   #1
Manugal
Senior Member
 
L'Avatar di Manugal
 
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?
Manugal è offline   Rispondi citando il messaggio o parte di esso
Old 19-10-2005, 20:42   #2
Manugal
Senior Member
 
L'Avatar di Manugal
 
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
Manugal è offline   Rispondi citando il messaggio o parte di esso
Old 19-10-2005, 21:15   #3
Ziosilvio
Moderatore
 
L'Avatar di Ziosilvio
 
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" Chi scherza col fuoco si brucia.
Scienza e tecnica: Matematica - Fisica - Chimica - Informatica - Software scientifico - Consulti medici
REGOLAMENTO DarthMaul = Asus FX505 Ryzen 7 3700U 8GB GeForce GTX 1650 Win10 + Ubuntu
Ziosilvio è offline   Rispondi citando il messaggio o parte di esso
Old 19-10-2005, 21:42   #4
Manugal
Senior Member
 
L'Avatar di Manugal
 
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.
Manugal è offline   Rispondi citando il messaggio o parte di esso
Old 20-10-2005, 11:44   #5
Ziosilvio
Moderatore
 
L'Avatar di Ziosilvio
 
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" Chi scherza col fuoco si brucia.
Scienza e tecnica: Matematica - Fisica - Chimica - Informatica - Software scientifico - Consulti medici
REGOLAMENTO DarthMaul = Asus FX505 Ryzen 7 3700U 8GB GeForce GTX 1650 Win10 + Ubuntu
Ziosilvio è offline   Rispondi citando il messaggio o parte di esso
Old 20-10-2005, 12:04   #6
Manugal
Senior Member
 
L'Avatar di Manugal
 
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.
Manugal è offline   Rispondi citando il messaggio o parte di esso
Old 20-10-2005, 12:08   #7
cionci
Senior Member
 
L'Avatar di cionci
 
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...
cionci è offline   Rispondi citando il messaggio o parte di esso
Old 20-10-2005, 12:18   #8
repne scasb
Bannato
 
Iscritto dal: Feb 2003
Messaggi: 947
Quote:
Originariamente inviato da Manugal
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?
http://www.hwupgrade.it/forum/showpo...8&postcount=33
repne scasb è offline   Rispondi citando il messaggio o parte di esso
Old 20-10-2005, 12:41   #9
Manugal
Senior Member
 
L'Avatar di Manugal
 
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?
Manugal è offline   Rispondi citando il messaggio o parte di esso
Old 20-10-2005, 12:59   #10
cionci
Senior Member
 
L'Avatar di cionci
 
Iscritto dal: Apr 2000
Città: Vicino a Montecatini(Pistoia) Moto:Kawasaki Ninja ZX-9R Scudetti: 29
Messaggi: 53971
Quote:
Originariamente inviato da Manugal
Grazie ma perché fino alla radice quadrata di n e non fino a n?
Perchè ho sbgliato Devi arrivare fino a n / 2... Supponendo k il divisore massimo di n allora n / k = j ====> j * k = n
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.
cionci è offline   Rispondi citando il messaggio o parte di esso
Old 20-10-2005, 14:33   #11
Ziosilvio
Moderatore
 
L'Avatar di Ziosilvio
 
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" Chi scherza col fuoco si brucia.
Scienza e tecnica: Matematica - Fisica - Chimica - Informatica - Software scientifico - Consulti medici
REGOLAMENTO DarthMaul = Asus FX505 Ryzen 7 3700U 8GB GeForce GTX 1650 Win10 + Ubuntu
Ziosilvio è offline   Rispondi citando il messaggio o parte di esso
Old 20-10-2005, 17:46   #12
Manugal
Senior Member
 
L'Avatar di Manugal
 
Iscritto dal: Jan 2001
Città: Villanova di Guidonia (RM)
Messaggi: 1079
Ok grazie ho capito molto gentili
Manugal è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Roborock Qrevo Curv 2 Flow: ora lava con un rullo Roborock Qrevo Curv 2 Flow: ora lava con un rull...
Alpine A290 alla prova: un'auto bella che ti fa innamorare, con qualche limite Alpine A290 alla prova: un'auto bella che ti fa ...
Recensione HONOR Magic 8 Lite: lo smartphone indistruttibile e instancabile Recensione HONOR Magic 8 Lite: lo smartphone ind...
Sony WF-1000X M6: le cuffie in-ear di riferimento migliorano ancora Sony WF-1000X M6: le cuffie in-ear di riferiment...
Snowflake porta l'IA dove sono i dati, anche grazie a un accordo con OpenAI Snowflake porta l'IA dove sono i dati, anche gra...
Oracle NetSuite si potenzia con nuove fu...
Musica generata con l'IA: Sony lavora a ...
Cyberpunk 2077 in versione PC su smartph...
BYD si gioca un grosso jolly: pronta Rac...
Samsung annuncia l'arrivo in Italia dei ...
Offerta lancio Pixel 10a: come ottenere ...
Google presenta Pixel 10a: poche le novi...
Caos F1 2026: 14 monoposto senza omologa...
Tesla festeggia il primo Cybercab prodot...
Desktop piccolo e potente? NZXT H2 Flow ...
Polestar spinge sull'acceleratore: arriv...
Nuovo record mondiale nel fotovoltaico: ...
L'ultimo baluardo cade: fine supporto pe...
'Il mondo non ha mai visto nulla di simi...
La Commissione europea mette sotto indag...
Chromium
GPU-Z
OCCT
LibreOffice Portable
Opera One Portable
Opera One 106
CCleaner Portable
CCleaner Standard
Cpu-Z
Driver NVIDIA GeForce 546.65 WHQL
SmartFTP
Trillian
Google Chrome Portable
Google Chrome 120
VirtualBox
Tutti gli articoli Tutte le news Tutti i download

Strumenti

Regole
Non Puoi aprire nuove discussioni
Non Puoi rispondere ai messaggi
Non Puoi allegare file
Non Puoi modificare i tuoi messaggi

Il codice vB è On
Le Faccine sono On
Il codice [IMG] è On
Il codice HTML è Off
Vai al Forum


Tutti gli orari sono GMT +1. Ora sono le: 03:01.


Powered by vBulletin® Version 3.6.4
Copyright ©2000 - 2026, Jelsoft Enterprises Ltd.
Served by www3v