Torna indietro   Hardware Upgrade Forum > Software > Programmazione

ASUS ROG Kithara: quando HIFIMAN incontra il gaming con driver planari da 100mm
ASUS ROG Kithara: quando HIFIMAN incontra il gaming con driver planari da 100mm
ASUS e HIFIMAN uniscono le forze per creare ROG Kithara, cuffie gaming con driver magnetici planari da 100mm, design open-back e microfono MEMS full-band. Una proposta che ambisce a coniugare fedeltà per audiofili e performance ludiche, disponibili a 319 euro
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
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 15-05-2003, 17:43   #1
lucianorossi
Senior Member
 
L'Avatar di lucianorossi
 
Iscritto dal: Nov 2002
Città: livorno
Messaggi: 873
programma c++

devo fare un proggy per calcolare i numeri primi per la scuola
Ho fatto una prima bozza in turbopascal
processo i primi 10000 numeri in 12 secondi [p4 1560mhz]
l'ho ribattuto in C++
l'ho migliorato più che ho potuto
250000 numeri processati in 12 secondi [solito proc]
ora però ho un problema: come andare oltre 250000 numeri?
perchè li devo memorizzare in un'array, ma non posso mandarlo oltre 250000 perchè se no il programma non parte, e non posso nemmeno fare una array doppio indice, perchè non parte lo stesso.
C'è un limite alla memoria utilizzaa? si può aumentare?
Uso Visual C++

Allego il programma
lucianorossi è offline   Rispondi citando il messaggio o parte di esso
Old 15-05-2003, 17:47   #2
lucianorossi
Senior Member
 
L'Avatar di lucianorossi
 
Iscritto dal: Nov 2002
Città: livorno
Messaggi: 873
eccolo
lucianorossi è offline   Rispondi citando il messaggio o parte di esso
Old 15-05-2003, 19:30   #3
a2000
Bannato
 
L'Avatar di a2000
 
Iscritto dal: Jan 2001
Messaggi: 1976
(un milione) di numeri processat
PII 350 MHz[/siz]
interpretato n VBA

tempo di calcolo 0.88 secondi[/siz]

Interessa ?
a2000 è offline   Rispondi citando il messaggio o parte di esso
Old 15-05-2003, 20:16   #4
misterx
Senior Member
 
Iscritto dal: Apr 2001
Città: Milano
Messaggi: 3741
Quote:
Originally posted by "a2000"

(un milione) di numeri processat
PII 350 MHz[/siz]
interpretato n VBA

tempo di calcolo 0.88 secondi[/siz]

Interessa ?

impossibile; tempo troppo basso
misterx è offline   Rispondi citando il messaggio o parte di esso
Old 15-05-2003, 20:22   #5
lucianorossi
Senior Member
 
L'Avatar di lucianorossi
 
Iscritto dal: Nov 2002
Città: livorno
Messaggi: 873
un milione in 1minuto e 7 secondi, per ora...
lucianorossi è offline   Rispondi citando il messaggio o parte di esso
Old 15-05-2003, 20:25   #6
lucianorossi
Senior Member
 
L'Avatar di lucianorossi
 
Iscritto dal: Nov 2002
Città: livorno
Messaggi: 873
è meglio fare un programma lungo che però faccia meno operazioni aritmetiche possibile o meglio farlo più corto e fargli fare un po' più di operazioni aritmetiche?
lucianorossi è offline   Rispondi citando il messaggio o parte di esso
Old 15-05-2003, 20:27   #7
misterx
Senior Member
 
Iscritto dal: Apr 2001
Città: Milano
Messaggi: 3741
magari vedendo il sorgente in C++ si potrebbe capire qualcosa in più
misterx è offline   Rispondi citando il messaggio o parte di esso
Old 15-05-2003, 20:41   #8
/\/\@®¢Ø
Bannato
 
L'Avatar di /\/\@®¢Ø
 
Iscritto dal: Jul 2000
Città: Malo (VI)
Messaggi: 1000
Quote:
Originally posted by "lucianorossi"

è meglio fare un programma lungo che però faccia meno operazioni aritmetiche possibile o meglio farlo più corto e fargli fare un po' più di operazioni aritmetiche?
Non e' possibile dire se sia meglio l'una o l'altra, dipende anche da quante volte ripeti le stesse operazioni. Piu' che contare le operazioni in questi casi e' meglio cercare l'algoritmo piu' adatto. Probabilmente il migliore e' la trivella di Eratostene (si chiama cosi' ? ), che suppongo sia la stessa tecnica che ha utilizzato a2000 (anzi, a onor del vero di questo argomento si era gia' parlato tempo fa, e mi sembra ne avesse accennato per primo lui)
L'idea e' abbastanza semplice: tieni una tabella di valori booleani che indichi se un numero e' primo o no. All'inizio tutti i valori della tabella sono veri, e man mano 'togli' tutti i multipli (per prima cosa togli i multipli di 2 poi quelli di 3 ... ).
Non dovrebbe risultare molto codice, 20 linee di codice basteranno.
/\/\@®¢Ø è offline   Rispondi citando il messaggio o parte di esso
Old 15-05-2003, 20:42   #9
/\/\@®¢Ø
Bannato
 
L'Avatar di /\/\@®¢Ø
 
Iscritto dal: Jul 2000
Città: Malo (VI)
Messaggi: 1000
Quote:
Originally posted by "misterx"




impossibile; tempo troppo basso
No, mi sembra piu' che ragionevole
/\/\@®¢Ø è offline   Rispondi citando il messaggio o parte di esso
Old 15-05-2003, 20:48   #10
a2000
Bannato
 
L'Avatar di a2000
 
Iscritto dal: Jan 2001
Messaggi: 1976
Quote:
Originally posted by "/\/\@®¢Ø"


No, mi sembra piu' che ragionevole
ohhh /\/\@®¢Ø !

"almeno tu nell'universooooo ...." :o :o :o
a2000 è offline   Rispondi citando il messaggio o parte di esso
Old 15-05-2003, 20:48   #11
lucianorossi
Senior Member
 
L'Avatar di lucianorossi
 
Iscritto dal: Nov 2002
Città: livorno
Messaggi: 873
grazie tante, questo è il primo programma che ho ideato, e girava benissimo, solo che non potevo fare un array di + di 250000 valori, e a me serve per trovare valori fra 2^128 e 2^129
C'è un metodo per fare un array di 2^129 valori?

Attualmente il codice è molto ingarbugliato, ora lo posto ma non so se ci capirete qualcosa
lucianorossi è offline   Rispondi citando il messaggio o parte di esso
Old 15-05-2003, 20:49   #12
lucianorossi
Senior Member
 
L'Avatar di lucianorossi
 
Iscritto dal: Nov 2002
Città: livorno
Messaggi: 873
CODICE: ATTENZIONE

#include <stdio.h>

void main()

{
unsigned long int a, b, c, d, e, f, h;
unsigned long int numerip[250000];
bool primo;
FILE *fw;
printf("Prime_Numbers v0.7.0.3 build 35 \n");
printf("Totalmente programmato da Giorgio Busoni \n");
printf("L''intevallo di numeri nel quale vuoi cercare i numeri primi \n");
printf("Digita la cifra di fine intervallo (massima) \n");
scanf("%d", &b);
printf(&"Please wait \n");
a=1;
fw = fopen("Primenumbers.txt","w");
c=a; /*copia a in un'altra variabile per non sovrascrivere il valore originario di a*/
if (b<=2)
{
printf("Il numero deve essere maggiore di 2 \n");
}
else
{
h=1;
numerip[2]=2;
while(c<b){
if(c>=250000)
{
break;
}
d=3;
e=c/2;
primo=true; /*il numero viene classificato come primo*/
while(numerip[d]<=e){
f= c % numerip[d]; /*resto delle divisione del numero per d (variabile che va da 2 a c-1)*/
numerip[h]=0;
if (f==0) /*se il resto=0...*/
{
primo=false; /*e viene anche memorizzato nella variabile temporanea*/
break;
}
d=d+1; /*si aumenta i divisore di 1 prima di ripetere l'operazione*/
}
if (primo==true) /*se alla fine del clico il numero non ha mai dato resto 0 in una divisione*/
{
numerip[h]=c; /*e il numero viene elencato nell'array come primo*/
if (numerip[h]==1)
{
numerip[h]=2;
}
fprintf(fw,"%d, " , numerip[h]);
h=h+1;
}
c=c+2; /*si passa al numero successivo prima di ripetere il ciclo*/
printf("Ready %d % \r", ((c*100)/(a*b)));
}
while(c<b){
if(c>5000000000)
{
break;
}
d=3;
e=c/2;
primo=true; /*il numero viene classificato come primo*/
while(numerip[d]<=e){
if (numerip[d]==0)
{
break;
}
f= c % numerip[d]; /*resto delle divisione del numero per d (variabile che va da 2 a c-1)*/
if (f==0) /*se il resto=0...*/
{
primo=false; /*e viene anche memorizzato nella variabile temporanea*/
break;
}
d=d+1; /*si aumenta i divisore di 1 prima di ripetere l'operazione*/
}
if (primo==true) /*se alla fine del clico il numero non ha mai dato resto 0 in una divisione*/
{
fprintf(fw,"%d, " , c);
}
c=c+2; /*si passa al numero successivo prima di ripetere il ciclo*/
if(c<b)
{
printf("Ready %d % \r", ((c*100)/(b)));
}
}
numerip[1]=2;
printf("Ricerca numeri primi completata");
}
}
lucianorossi è offline   Rispondi citando il messaggio o parte di esso
Old 15-05-2003, 20:50   #13
a2000
Bannato
 
L'Avatar di a2000
 
Iscritto dal: Jan 2001
Messaggi: 1976
Quote:
Originally posted by "misterx"




impossibile; tempo troppo basso
provare per credere.

interessa ?
a2000 è offline   Rispondi citando il messaggio o parte di esso
Old 15-05-2003, 20:50   #14
lucianorossi
Senior Member
 
L'Avatar di lucianorossi
 
Iscritto dal: Nov 2002
Città: livorno
Messaggi: 873
versione compilata e zippata aggiornata
lucianorossi è offline   Rispondi citando il messaggio o parte di esso
Old 15-05-2003, 20:50   #15
lucianorossi
Senior Member
 
L'Avatar di lucianorossi
 
Iscritto dal: Nov 2002
Città: livorno
Messaggi: 873
Quote:
Originally posted by "a2000"



provare per credere.

interessa ?
si, se completo di codice
lucianorossi è offline   Rispondi citando il messaggio o parte di esso
Old 15-05-2003, 21:58   #16
a2000
Bannato
 
L'Avatar di a2000
 
Iscritto dal: Jan 2001
Messaggi: 1976
per ora il codice (12 righe).

Codice:
Sub Primi()
 
  Const iMax& = 250000000
  Dim i As Long, j As Long
  Dim aaa(1 To iMax) As Byte
 
  For i = 2 To Sqr(iMax)
   If aaa(i) = 0 Then
    For j = 2 * i To iMax Step i
     aaa(j) = 1
    Next j
   End If
  Next i

End Sub
a2000 è offline   Rispondi citando il messaggio o parte di esso
Old 15-05-2003, 22:16   #17
a2000
Bannato
 
L'Avatar di a2000
 
Iscritto dal: Jan 2001
Messaggi: 1976
... adesso non ho tempo.

comunque, come sempre, l'algoritmo è TUTTO e ce ne sono tanti anche per intervalli numerici molto grandi.

ma la cosa divertente è comunque cimentarsi per trovare qualche soluzione personale e originale (ma semplice ed elegante).
con l'algoritmo del crivello di Eratostene naive il limite è la memoria di massa disponibile sulla macchina.
con qualche pensata sulla virtualizzazione del vettore aaa() e considerando che per valori di n molto grandi "quasi" tutti i numeri sono primi .... 2^129 non è poi così grande.

a2000 è offline   Rispondi citando il messaggio o parte di esso
Old 15-05-2003, 22:25   #18
a2000
Bannato
 
L'Avatar di a2000
 
Iscritto dal: Jan 2001
Messaggi: 1976
comunque qualcosa bisogna saperla:

http://matematica.uni-bocconi.it/betti/AKS.htm
a2000 è offline   Rispondi citando il messaggio o parte di esso
Old 15-05-2003, 22:36   #19
lucianorossi
Senior Member
 
L'Avatar di lucianorossi
 
Iscritto dal: Nov 2002
Città: livorno
Messaggi: 873
cosa vuol dire dim?
che linguaggio è?
sul visual c++ non parte correttamente
lucianorossi è offline   Rispondi citando il messaggio o parte di esso
Old 15-05-2003, 23:00   #20
/\/\@®¢Ø
Bannato
 
L'Avatar di /\/\@®¢Ø
 
Iscritto dal: Jul 2000
Città: Malo (VI)
Messaggi: 1000
In C++ puoi usare qualcosa del genere, per il calcolo e la stampa.
Codice:
#include <iostream>
#include <cmath>
#include <vector>
int main()
{
    unsigned long n = 1000000;
    bool data[n];
    fill( data , data + n , true );
    data[0] = data[1] = false;
    for ( unsigned long i=2 ; i < sqrt(n) ; ++i )
        if ( data[i] )
        {
            unsigned long m = i*2;
            do
            {
                data[m]=false;
                m+=i;
            }while( m < n );
        }
    for ( unsigned long i=0 ; i<n ; ++i )
        if (data[i] )
            cout << i << endl;
}
anche se cosi' come e' fatto non puoi arrivare a cifre dell'ordine del 2^128
/\/\@®¢Ø è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


ASUS ROG Kithara: quando HIFIMAN incontra il gaming con driver planari da 100mm ASUS ROG Kithara: quando HIFIMAN incontra il gam...
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...
TV Toshiba 4K a prezzi folli: il QLED 65...
Sony svela i requisiti PC di Death Stran...
Addio GPU? MatX promette un chip 10 volt...
Amazon taglia i prezzi dei dispositivi F...
Amazon, stop del Garante alla raccolta d...
LEGO Game Boy a 45,99€ su Amazon: la con...
Kit Logitech MK950 Signature Slim a 79,9...
Discord rinvia la verifica dell'et&agrav...
Blizzard annuncia Overwatch Rush, lo spi...
Windows 11, l'ultimo aggiornamento opzio...
Intel e SambaNova, nessuna acquisizione ...
Marvel's Wolverine: rivelata la data d'u...
Samsung contrasta la crisi delle memorie...
Stampante Wi-Fi a meno di 40€? HP DeskJe...
Google Pixel 10 base a 563€ è il ...
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: 11:03.


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