|
|||||||
|
|
|
![]() |
|
|
Strumenti |
|
|
#1 |
|
Senior Member
Iscritto dal: May 2008
Messaggi: 1566
|
[C]Long double
Ciao a tutti. Ho bisogno di fare un programma che generi numeri primi all'infinito. Siccome c'è una sorta di "gara" in classe vorrei ovviamente vincerla. Per cui il numero dovrà essere sufficientemente grande, e ovviamente una variabile intera non è sufficiente.
Per cui ho pensato alle long double, che sono grandi 12 Byte = 96 bit. Dovrebbe bastare. Il problema è che per la verifica dei numeri primi non si può usare il modulo, da errore. Come faccio a verificare se il numero in long double è primo??
__________________
CM Obsidian 750D - Corsair TX650M - AMD Ryzen 7 3700x - Asus TUF B550-PLUS - nVidia Gigabyte GTX 1060 6GB G1 Gaming - Noctua D15S - Corsair Vengeance Pro 3600MHz 16GB - 2xHP x27i - Razer Deathadder - Logitech G15 v1 nVidia Edition- Roccat Taito King-Size - Fastweb (2011) | Alice(2015) | Alice(2016) | Eolo 30Mb (2016) | Wind3 4G Flat (2019) | PF AIR 100 (2021) |
|
|
|
|
|
#2 |
|
Senior Member
Iscritto dal: Feb 2006
Città: Parma
Messaggi: 3010
|
Non è meglio un long long, magari pure unsigned?
__________________
~Breve riferimento ai comandi GNU/Linux (ormai non molto breve...) |
|
|
|
|
|
#3 |
|
Senior Member
Iscritto dal: May 2008
Messaggi: 1566
|
Unsigned da errore
Long long è meglio. Consigli sulla verifica numeri primi?
__________________
CM Obsidian 750D - Corsair TX650M - AMD Ryzen 7 3700x - Asus TUF B550-PLUS - nVidia Gigabyte GTX 1060 6GB G1 Gaming - Noctua D15S - Corsair Vengeance Pro 3600MHz 16GB - 2xHP x27i - Razer Deathadder - Logitech G15 v1 nVidia Edition- Roccat Taito King-Size - Fastweb (2011) | Alice(2015) | Alice(2016) | Eolo 30Mb (2016) | Wind3 4G Flat (2019) | PF AIR 100 (2021) |
|
|
|
|
|
#4 |
|
Senior Member
Iscritto dal: Oct 2004
Messaggi: 1945
|
|
|
|
|
|
|
#5 | |
|
Member
Iscritto dal: Mar 2008
Messaggi: 267
|
Quote:
Come ti hanno detto, un unsigned long long può fare al caso tuo. Immagino che tu conosca già l'algoritmo per controllare se un numero è primo, ma se il tuo obiettivo è quello di listare i numeri primi, controllare tutti i numeri uno ad uno potrebbe diventare un po' lento. Una soluzione potrebbe essere quella di usare un vettore dinamico (o una lista) in cui memorizzi tutte le soluzioni precedenti (i fattori), e per controllare se un numero è primo parti dalle soluzioni precedenti e ne trovi di nuove, aggiungendole alla lista. |
|
|
|
|
|
|
#6 |
|
Senior Member
Iscritto dal: May 2008
Messaggi: 1566
|
Allora sono andato avanti.
Per ora uso unsigned long long int (che a quanto pare è di 64bit), cosi posso usare il modulo %. I risultati li salvo su file, e quando riapro il file automaticamente carica l ultimo numero salvato! Se volessi qualcosa di più grande di 64bit come si può fare?
__________________
CM Obsidian 750D - Corsair TX650M - AMD Ryzen 7 3700x - Asus TUF B550-PLUS - nVidia Gigabyte GTX 1060 6GB G1 Gaming - Noctua D15S - Corsair Vengeance Pro 3600MHz 16GB - 2xHP x27i - Razer Deathadder - Logitech G15 v1 nVidia Edition- Roccat Taito King-Size - Fastweb (2011) | Alice(2015) | Alice(2016) | Eolo 30Mb (2016) | Wind3 4G Flat (2019) | PF AIR 100 (2021) |
|
|
|
|
|
#7 |
|
Member
Iscritto dal: Mar 2008
Messaggi: 267
|
Non credo che tu riesca ad arrivare ad un numero primo che sia maggiore di 18446744073709551616 (2^64 - 1).
In ogni caso per avere più di 64 bit ti tocca usare numeri a precisione arbitraria (i cosiddetti BigNum). Il modo più semplice per farlo è quello di appoggiarsi a librerie esterne che puoi reperire facilmente su internet. |
|
|
|
|
|
#8 |
|
Senior Member
Iscritto dal: May 2008
Messaggi: 1566
|
Ho fatto il programma con i long double e funziona.
Ora ho solo un problema. Quando i numeri diventeranno mooolto grandi, il cout di default mi visualizzerà qualche cifra seguita da un esponente. Come faccio a evitare di visualizzare l'esponente e vedere il numero per intero?
__________________
CM Obsidian 750D - Corsair TX650M - AMD Ryzen 7 3700x - Asus TUF B550-PLUS - nVidia Gigabyte GTX 1060 6GB G1 Gaming - Noctua D15S - Corsair Vengeance Pro 3600MHz 16GB - 2xHP x27i - Razer Deathadder - Logitech G15 v1 nVidia Edition- Roccat Taito King-Size - Fastweb (2011) | Alice(2015) | Alice(2016) | Eolo 30Mb (2016) | Wind3 4G Flat (2019) | PF AIR 100 (2021) |
|
|
|
|
|
#9 | |
|
Member
Iscritto dal: Mar 2008
Messaggi: 267
|
Quote:
Volendo puoi forzare la visualizzazione, ma non vedrai altro che una fila di 0. Ti faccio un esempio: 2+1 = 3 (questo lo riesce a rappresentare, visto che è un numero piccolo) 20+1 = 21 (idem) ... 2000000000000000000000000000000000+1 = 2000000000000000000000000000000000 (in questo caso non può farci niente, perché la precisione non è abbastanza elevata da permettere di memorizzare quell'1 meno significativo). Proprio per questo motivo ti sconsiglierei di usare i double, visto che il loro range di numeri è elevato, ma non è distribuito uniformemente tra tutti i numeri. |
|
|
|
|
|
|
#10 |
|
Senior Member
Iscritto dal: Jan 2006
Città: Perugia - San Benedetto del Tronto
Messaggi: 348
|
Il test di primalità non è per nulla banale, e gioca un ruolo molto importante nell'ambito della crittografia.
Puoi ricorrere a test non deterministici -quindi più test fai più aumenti la certezza riguardo al fatto che il numero sia primo- e tutti si basano su un concetto molto semplice: se un numero è primo, gode di determinate proprietà. Matematicamente invece beh, è un altro discorso Dai un occhio qua, trovi i più importanti: Soloway-Strassen, Miller-Rabin e il Test di Fermat: http://www.dti.unimi.it/citrini/MD/S.../sol-stras.htm |
|
|
|
|
| Strumenti | |
|
|
Tutti gli orari sono GMT +1. Ora sono le: 19:40.




















