Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Gigabyte MO32U24 OLED: il 4K a 240Hz su un pannello OLED ideale per il gaming
Gigabyte MO32U24 OLED: il 4K a 240Hz su un pannello OLED ideale per il gaming
Pannello QD-OLED da 32 pollici con risoluzione 4K, frequenza di aggiornamento a 240Hz e tempi di risposta rapidissimi: il Gigabyte MO32U24 evolve il progetto del suo predecessore MO32U e alza ulteriormente l'asticella delle prestazioni. È ancora una volta un monitor indirizzato ai giocatori più esigenti
Recensione realme 16 5G: lo smartphone con Selfie Mirror ha una batteria da 6550mAh
Recensione realme 16 5G: lo smartphone con Selfie Mirror ha una batteria da 6550mAh
realme 16 5G è un nuovo smartphone con sensore Sony IMX 852 da 50MP sul retro e uno specchio selfie fisico integrato nella camera bar, una prima nel segmento di mercato. Batteria da 6550mAh in un corpo da 8,1mm e 183g, certificazione IP69K e ricarica da 45W completano un pacchetto aggressivo per la fascia media, per uno dei prodotti più interessanti del produttore sul piano commerciale
Come rispettare tutte le nuove regole per i monopattini elettrici? La guida per non rischiare sanzioni
Come rispettare tutte le nuove regole per i monopattini elettrici? La guida per non rischiare sanzioni
Sono ormai definitive le nuove norme del Codice della Strada per i monopattini elettrici. Non solo targa e assicurazione, le regole sono tante e riguardano diversi aspetti, vi spieghiamo come evitare sanzioni che possono essere salate
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 20-04-2011, 20:36   #1
L4ky
Senior Member
 
L'Avatar di L4ky
 
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)
L4ky è offline   Rispondi citando il messaggio o parte di esso
Old 20-04-2011, 21:00   #2
Gimli[2BV!2B]
Senior Member
 
L'Avatar di Gimli[2BV!2B]
 
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...)
Gimli[2BV!2B] è offline   Rispondi citando il messaggio o parte di esso
Old 20-04-2011, 21:05   #3
L4ky
Senior Member
 
L'Avatar di L4ky
 
Iscritto dal: May 2008
Messaggi: 1566
Quote:
Originariamente inviato da Gimli[2BV!2B] Guarda i messaggi
Non è meglio un long long, magari pure unsigned?
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)
L4ky è offline   Rispondi citando il messaggio o parte di esso
Old 20-04-2011, 21:34   #4
clockover
Senior Member
 
L'Avatar di clockover
 
Iscritto dal: Oct 2004
Messaggi: 1945
Quote:
Originariamente inviato da L4ky Guarda i messaggi
Unsigned da errore
Long long è meglio.
Consigli sulla verifica numeri primi?
Fa una ricerca qui in programmazione... ricordo una discussione analoga un po di tempo fa
clockover è offline   Rispondi citando il messaggio o parte di esso
Old 20-04-2011, 22:16   #5
Supdario
Member
 
Iscritto dal: Mar 2008
Messaggi: 267
Quote:
Originariamente inviato da L4ky Guarda i messaggi
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??
Un long double ha la dimensione di 80 bit, e tuttavia non è supportato da tutti i compilatori (anzi, ormai sta diventando una feature deprecata in tutti i compilatori dato che ormai tutti i calcoli FPU vengono eseguiti a 64 bit, anche per via delle istruzioni SSE che permettono al massimo numeri di 64 bit).

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.
Supdario è offline   Rispondi citando il messaggio o parte di esso
Old 20-04-2011, 22:24   #6
L4ky
Senior Member
 
L'Avatar di L4ky
 
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)
L4ky è offline   Rispondi citando il messaggio o parte di esso
Old 20-04-2011, 22:56   #7
Supdario
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.
Supdario è offline   Rispondi citando il messaggio o parte di esso
Old 21-04-2011, 08:41   #8
L4ky
Senior Member
 
L'Avatar di L4ky
 
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)
L4ky è offline   Rispondi citando il messaggio o parte di esso
Old 21-04-2011, 10:54   #9
Supdario
Member
 
Iscritto dal: Mar 2008
Messaggi: 267
Quote:
Originariamente inviato da L4ky Guarda i messaggi
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?
Non puoi, perché per loro natura i numeri a virgola mobile vengono memorizzati in notazione esponenziale, quindi quando diventano grossi iniziano a perdere precisione e certi numeri non possono essere rappresentati.
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.
Supdario è offline   Rispondi citando il messaggio o parte di esso
Old 21-04-2011, 20:04   #10
:.Blizzard.:
Senior Member
 
L'Avatar di :.Blizzard.:
 
Iscritto dal: Jan 2006
Città: Perugia - San Benedetto del Tronto
Messaggi: 348
Quote:
Originariamente inviato da L4ky Guarda i messaggi
Consigli sulla verifica numeri primi?
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
:.Blizzard.: è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Gigabyte MO32U24 OLED: il 4K a 240Hz su un pannello OLED ideale per il gaming Gigabyte MO32U24 OLED: il 4K a 240Hz su un panne...
Recensione realme 16 5G: lo smartphone con Selfie Mirror ha una batteria da 6550mAh Recensione realme 16 5G: lo smartphone con Selfi...
Come rispettare tutte le nuove regole per i monopattini elettrici? La guida per non rischiare sanzioni Come rispettare tutte le nuove regole per i mono...
DLSS 4.5: con Dynamic Frame Generation e MFG 6X NVIDIA alza la posta DLSS 4.5: con Dynamic Frame Generation e MFG 6X ...
Plaud NotePin S, il registratore IA si fa indossabile (ma è facile da perdere) Plaud NotePin S, il registratore IA si fa indoss...
Samsung Galaxy A27 5G è ufficiale...
TCL aggiorna la sua gamma di monitor per...
Anche OPPO avrà uno smartphone co...
La Radeon RX 9070 XT appare su Steam e m...
L'America si ribella ai datacenter: bloc...
'Artificial General Engineer': l'IA di J...
Il drone NASA Dragonfly, che voler&agrav...
Stop immediato a Fable 5 e Mythos 5: il ...
"Prime Day Amazon il 23-26 giugno": sì e...
Oggi 2 super MacBook Pro M5 e M5 Pro, 24...
Tineco Floor One Station S9 Artist: il s...
Raggiunte nuove altitudine e velocit&agr...
Apple Watch Series 11 GPS a 339€ su Amaz...
Come un MacBook, ma con la RTX 5070: MSI...
Paolo Zaccardi: "Smettere di assume...
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: 16:26.


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