Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Recensione OPPO Find X9 Ultra: è lui il cameraphone definitivo
Recensione OPPO Find X9 Ultra: è lui il cameraphone definitivo
Find X9 Ultra è lo smartphone che tanti aspettavano, e finalmente è arrivato anche in Italia. Abbiamo provato il flagship di OPPO per diverse settimane, e siamo volati fino in Cina alla sua presentazione ufficiale. Tutto gira intorno al suo incredibile comparto fotografico in collaborazione con Hasselblad e con un totale di sei fotocamere. Il resto è un mix di specifiche di altissimo livello, così come il prezzo. Vi raccontiamo tutto nella nostra recensione completa.
Ecovacs Deebot X12 OmniCyclone: lava grazie a FocusJet
Ecovacs Deebot X12 OmniCyclone: lava grazie a FocusJet
Il nuovo Deebot X12 OmniCyclone abbina un sistema di raccolta dello sporco senza sacchetto, un rullo di lavaggio esteso e la tecnologia FocusJet per intervenire più efficacemente sulle macchie più persistenti. Un robot completo e preciso che aiuta a tenere puliti i pavimenti di casa con il minimo sforzo
Narwal Flow 2: la pulizia di casa con un mocio a nastro
Narwal Flow 2: la pulizia di casa con un mocio a nastro
Narwal Flow 2 implementa un mocio a nastro che esegue una pulizia dettagliata del pavimento di casa, in abbinamento ad un potente motore di aspirazione della polvere: un prodotto ideale per gestire in autonomia e con grande efficacia le necessità di pulizia dei pavimenti di casa
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 15-05-2003, 16: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, 16: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, 18: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, 19: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, 19: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, 19: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, 19: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, 19: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, 19: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, 19: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, 19: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, 19: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, 19: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, 19: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, 19: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, 20: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, 21: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, 21: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, 21: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, 22: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


Recensione OPPO Find X9 Ultra: è lui il cameraphone definitivo Recensione OPPO Find X9 Ultra: è lui il c...
Ecovacs Deebot X12 OmniCyclone: lava grazie a FocusJet Ecovacs Deebot X12 OmniCyclone: lava grazie a Fo...
Narwal Flow 2: la pulizia di casa con un mocio a nastro Narwal Flow 2: la pulizia di casa con un mocio a...
Tastiera gaming MSI GK600 TKL: switch hot-swap, display LCD e tre modalità wireless Tastiera gaming MSI GK600 TKL: switch hot-swap, ...
DJI Osmo Pocket 4: la gimbal camera tascabile cresce e ha nuovi controlli fisici DJI Osmo Pocket 4: la gimbal camera tascabile cr...
Il rover NASA Curiosity ha scoperto oltr...
Il satellite AST SpaceMobile BlueBird 7 ...
SpaceX: la droneship Just Read the Instr...
Project Helix sarà prodotta anche...
La NASA pubblica alcuni aggiornamenti su...
Tute spaziali AxEMU per Artemis: Axiom S...
Nutanix Government Cloud Clusters arriva...
Troy Baker lavora a un progetto tutto su...
Motorola Edge 60 Neo è il compatt...
Stretto di Hormuz, finti funzionari iran...
Dragon Ball Xenoverse 3 annunciato uffic...
WINDTRE BUSINESS potenzia i servizi IoT ...
OPPO rinnova l'ecosistema: arrivano Watc...
OPPO Find X9 Ultra ufficiale: debutta il...
Renault Twingo: esposta a Milano per far...
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: 21:30.


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