Torna indietro   Hardware Upgrade Forum > Software > Programmazione

DJI Lito 1 e Lito X1 recensione: i nuovi droni per principianti che non si fanno mancare nulla
DJI Lito 1 e Lito X1 recensione: i nuovi droni per principianti che non si fanno mancare nulla
DJI ha appena ufficializzato la serie Lito, la sua nuova gamma di droni entry-level destinata a chi si avvicina per la prima volta alla fotografia aerea. Al centro dell'annuncio ci sono due modelli ben distinti per fascia di prezzo e specifiche tecniche: DJI Lito 1 e DJI Lito X1. Entrambi si collocano sotto la soglia regolamentare dei 249 grammi, che permette di volare con requisiti burocratici più semplici rispetto ai droni più pesanti.
Sony World Photography Awards 2026: i premiati, anche italiani, il punto sulla fotografia di oggi
Sony World Photography Awards 2026: i premiati, anche italiani, il punto sulla fotografia di oggi
Siamo stati a Londra per la premiazione dei Sony World Photography Awards 2026, l'evento a tema fotografia più prestigioso. Fra sorprese e novità, ne approfittiamo per fare il punto sulla fotografia contemporanea, in cui la didascalia è sempre più necessaria a cogliere il senso della quasi totalità degli scatti.
Una settimana con Hyundai Ioniq 5 N-Line: diverte e convince
Una settimana con Hyundai Ioniq 5 N-Line: diverte e convince
L'elettrica di casa Hyundai propone una versione AWD con estetica derivata dalla famiglia N. L'abbiamo provata per diversi giorni, per scoprire tutti i dettagli e la vera autonomia in autostrada
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 18-07-2007, 08:13   #1
xbubbax
Senior Member
 
Iscritto dal: Apr 2007
Messaggi: 381
[C] Crivello di Eratostene

Qualcuno mi sa dire perchè non funziona questo programma? E' stato più facile del previsto farlo, ma non funge

#include <stdio.h>
#define SIZE 20

int main(){

int n;
int a[SIZE];
int i;
int j=2;

for(i=0;i<SIZE;i++){
a[i]=1;}

printf("Inserisci un intero n:\n");
scanf("&d", &n);
for(j=2;j<n;j++){
for(i=2;i<=n;i++){
if((i!=j)&&((i%j)==0)){
a[i]=0;}}}
for(i=0;i<n;i++){
if(a[i]==1){
printf("%d\n", a[i]);}}}
xbubbax è offline   Rispondi citando il messaggio o parte di esso
Old 18-07-2007, 08:14   #2
xbubbax
Senior Member
 
Iscritto dal: Apr 2007
Messaggi: 381
Il programma deve trovare i numeri primi da 1 a n
xbubbax è offline   Rispondi citando il messaggio o parte di esso
Old 18-07-2007, 08:59   #3
pisto
 
Messaggi: n/a
è il primo thread su C a cui rispondo, potrei dir cazzate... ho incominciato a guardarmi il C ieri e sto ancora tribolando ad installare il compilatore quindi non posso testare..

cmq: prima di tutto il tuo programma crea un array di dimensione fissa, quindi evidentemente non può trovare i numeri primi fino ad n ad ogni valore di n. quindi la lunghezza dell'array che crei deve dipendere da n.

poi, nei for che fanno effettivamente il crivello ti complichi la vita, basterebbe moltiplicare j da 2 in poi (controllare che il risultato non sia superiore alla lunghezza dell'array) e mettere 0 nel rispettivo indice dell'array ottenuto da questa operazione. attualmente con il tuo programma rischi di superare il limite dell'array fino al quadrato della sua dimensione!

ci sarebbero altre ottimizzazioni, ma per adesso guarda se con queste correzioni va.
  Rispondi citando il messaggio o parte di esso
Old 18-07-2007, 09:18   #4
mapomapo
Senior Member
 
L'Avatar di mapomapo
 
Iscritto dal: May 2005
Città: Bari
Messaggi: 349
Codice:
#include <stdio.h>
#include <stdlib.h>

void main()
{

	int n;
	int *a;
	int i;
	int j=2;

	printf("Inserisci un intero n: ");
	scanf("%d", &n);

	a = (int *)malloc((n+2)*sizeof(int));

	for(i=0;i<n;i++)
		a[i]=1;

	for(j=2;j<n;j++)
		for(i=2;i<n;i++)
			if( (i != j) && ( (i%j)==0 ) )
				a[i]=0;
	

	for(i=2;i<n;i++)
		if(a[i]==1)
			printf("%d ", i);
        printf("\n");

}
Ho provato a riscriverlo visto che non capivo bene la tua logica, scusami ma sono abituato così
il mio programmino lavora in questa maniera:
-Acquisisce il numero n secondo il criterio di Eratostene
-Alloca un vettore di n+2 elementi (così posso lavorare sull'indice del vettore!)
-Esegue un paio di for annidati e credo in questo caso operi secondo la tua stessa logica.

Vito
__________________
Si può vincere una guerra in due...o forse anche da solo. Si può estrarre il cuore anche al più nero assassino, ma è più difficile cambiare un'idea!
mapomapo è offline   Rispondi citando il messaggio o parte di esso
Old 18-07-2007, 09:36   #5
pisto
 
Messaggi: n/a
Quote:
Originariamente inviato da mapomapo Guarda i messaggi
Codice:
for(j=2;j<n;j++)
	for(i=2;i<n;i++)
		if( (i != j) && ( (i%j)==0 ) )
			a[i]=0;
sì in effetti ho detto una cazzata, così funziona perfettamente questa parte, non va oltre il limite dell'array.
però, non sarebbe molto + semplice una cosa tipo:
Codice:
for(j=2;j<=n/2;j++){
  for(i=2;i<=n/j;i++){
    a[i]=0;
  }
}
  Rispondi citando il messaggio o parte di esso
Old 18-07-2007, 09:43   #6
LetBloodline
Junior Member
 
Iscritto dal: Jul 2007
Messaggi: 27
Quote:
Originariamente inviato da pisto Guarda i messaggi
sì in effetti ho detto una cazzata, così funziona perfettamente questa parte, non va oltre il limite dell'array.
però, non sarebbe molto + semplice una cosa tipo:
Codice:
for(j=2;j<=n/2;j++){
  for(i=2;i<=n/j;i++){
    a[i]=0;
  }
}
Ma così metti a 0 tutti gli elementi dell'array da 2 a n/2 Oo

Codice:
for(i=2;i<=n/j;i++){
    a[i]=0;
nella prima interazione j vale 2 e avremo
Codice:
for(i=2;i<=n/2,i++){
    a[i]=0;
Prende tutta la prima metà dell'array e la mette a 0 a partire dall'indice 2, compresi 3 5 7 9 etc
LetBloodline è offline   Rispondi citando il messaggio o parte di esso
Old 18-07-2007, 09:59   #7
Furla
Senior Member
 
Iscritto dal: Feb 2004
Messaggi: 1454
il verbo "Indentare" ti dice nulla?
faresti un favore a te e agli altri, se rendessi il tuo codice leggibile:

Codice:
int main()
{
 int n;
 int a[SIZE];
 int i;
 int j=2;

 for(i=0;i<SIZE;i++)
    a[i]=1;

 printf("Inserisci un intero n:\n");
 scanf("%d", &n);

 for(j=2; j<n; j++)
    for(i=2; i<=n; i++)
        if(i!=j && i%j==0)
            a[i]=0;

 for(i=0; i<n; i++)
    if(a[i]==1)
        printf("%d\n", a[i]);
}
prima di tutto le parentesi graffe le puoi togliere, quando il corpo del costrutto prevede una sola istruzione: in quei casi appesantiscono e confondono la lettura.

poi tu usi un array di interi, ma li usi come flag binari. potresti usare il tipo char per ottimizzare lo spazio, o addirittura usare un solo bit per numero giocando con maschere e shift. inoltre usi un array di dimensione fissa senza alcun controllo sul numero inserito: o aggiungi il controllo o allochi dinamicamente l'array per "adeguarlo" a quel numero.

nell'ultimo for controlli che a[i] sia uno, e se è così lo stampi... ovvio che il programma stampi a video una serie di "1"... quello che volevi fare era stampare gli indici i per i quali il flag è rimasto a 1 dopo l'applicazione del crivello.

Ultima modifica di Furla : 18-07-2007 alle 18:08.
Furla è offline   Rispondi citando il messaggio o parte di esso
Old 18-07-2007, 13:30   #8
xbubbax
Senior Member
 
Iscritto dal: Apr 2007
Messaggi: 381
Grazie mille per le risposte

Tra un'oretta le comincio a guardare, ora sono impegnato in un altro programmino
xbubbax è offline   Rispondi citando il messaggio o parte di esso
Old 18-07-2007, 14:46   #9
xbubbax
Senior Member
 
Iscritto dal: Apr 2007
Messaggi: 381
scusate ma non so proprio come incollarlo bene, come fate voi

comq ho modificato una cosetta ma come risultato mi da 1, non capisco dove sbaglio


#include <stdio.h>
#define SIZE 20

int main(){

int n;
int a[n];
int i;
int j=2;

printf("Inserisci un intero n:\n");
scanf("&d", &n);

for(i=0;i<n;i++){
a[i]=1;}


for(j=2;j<n;j++){
for(i=2;i<=n;i++){
if((i!=j)&&((i%j)==0)){
a[i]=0;}}}
for(i=0;i<n;i++){
if(a[i]==1){
printf("%d\n", a[i]);}} }
xbubbax è offline   Rispondi citando il messaggio o parte di esso
Old 18-07-2007, 14:48   #10
xbubbax
Senior Member
 
Iscritto dal: Apr 2007
Messaggi: 381
ho modificato un'altra cosetta e ora mi da 0 e 1 come risultato

#include <stdio.h>
#define SIZE 20

int main(){

int n;
int a[n];
int i;
int j=2;

printf("Inserisci un intero n:\n");
scanf("&d", &n);

for(i=0;i<n;i++){
a[i]=1;}


for(j=2;j<n;j++){
for(i=2;i<=n;i++){
if((i!=j)&&((i%j)==0)){
a[i]=0;}}}
for(i=0;i<n;i++){
if(a[i]==1){
printf("%d\n", i);}}
xbubbax è offline   Rispondi citando il messaggio o parte di esso
Old 18-07-2007, 14:53   #11
pisto
 
Messaggi: n/a
cribbio, volevo dire:
Codice:
for(j=2;j<=n/2;j++){
  for(i=2;i<=n/j;i++){
    a[j*i]=0;
  }
}
il che è mooolto più veloce dell'iterazione di bubba

edit: facendo dei test in java: col mio metodo fino a 10000000 ci vogliono col mio 13.5 secondi, col suo.... sta ancora girando XD

Ultima modifica di pisto : 18-07-2007 alle 15:08.
  Rispondi citando il messaggio o parte di esso
Old 18-07-2007, 14:56   #12
xbubbax
Senior Member
 
Iscritto dal: Apr 2007
Messaggi: 381
ho provato a mettere il pezzo che dici tu ma mi da sempre 0 e 1, come se il 2,3,5 ecc..non li conta come primi, forse sbaglio quando stampo il risultato

#include <stdio.h>
#define SIZE 20

int main(){

int n;
int a[n];
int i;
int j=2;

printf("Inserisci un intero n:\n");
scanf("&d", &n);

for(i=0;i<n;i++){
a[i]=1;}


for(j=2;j<=n/2;j++){
for(i=2;i<=n/j;i++){
a[j*i]=0;
}
}
for(i=0;i<n;i++){
if(a[i]==1){
printf("%d\n", i);}}
xbubbax è offline   Rispondi citando il messaggio o parte di esso
Old 18-07-2007, 15:11   #13
pisto
 
Messaggi: n/a
la parte di codice che stampa è corretta, almeno come hai costruito il ciclo for, credo che sia qualcosa che non va in "printf("%d\n", i)", ma non ti so aiutare, io di c sto ancora a dichiarazione e definizione, include etcetera

edit: prova a mettere printf("%d", i)
edit2: segui il consiglio di Furla, cioè di alleggerire l'array...
edit3: aspetta, ma tu mi stai dicendo che ti stampa 0 e 1, e poi la serie corretta? allora basta che modifichi il ciclo di stampa così:
Codice:
for(i=2;i<n;i++)
  if(a[i]==1)
    printf("%d", i);

Ultima modifica di pisto : 18-07-2007 alle 15:17.
  Rispondi citando il messaggio o parte di esso
Old 18-07-2007, 16:19   #14
mastoo
Member
 
Iscritto dal: Apr 2006
Città: V.E. (na)
Messaggi: 115
Quote:
Originariamente inviato da xbubbax Guarda i messaggi
ho provato a mettere il pezzo che dici tu ma mi da sempre 0 e 1, come se il 2,3,5 ecc..non li conta come primi, forse sbaglio quando stampo il risultato

#include <stdio.h>
#define SIZE 20

int main(){

int n;
int a[n]; é qui il problema
int i;
int j=2;

printf("Inserisci un intero n:\n");
scanf("&d", &n);

for(i=0;i<n;i++){
a[i]=1;}


for(j=2;j<=n/2;j++){
for(i=2;i<=n/j;i++){
a[j*i]=0;
}
}
for(i=0;i<n;i++){
if(a[i]==1){
printf("%d\n", i);}}
il fatto è che quel vettore non ha una dimensione n come credi tu perche la variabile n non è stata inizializzata protrebbe contenere qualsiasi valore intero
devi fare come ti ha detto mapomapo o fai il vettore di dimensione fissa
cosi tipo
Codice:
#include <stdio.h>
#define SIZE 20

main()
{

	int a[SIZE+1]; 
	int i, j;

	for(i=0;i<SIZE;i++)
		a[i]=1;
	
	
	for(j=2;j<=SIZE/2;j++)
		for(i=2;i<=SIZE/j;i++)
			 a[j*i]=0;


	/*stampa*/
	for(i=2;i<SIZE;i++)
		if(a[i]==1)
			printf("%d\n", i);
	 
		
}
mastoo è offline   Rispondi citando il messaggio o parte di esso
Old 18-07-2007, 17:49   #15
xbubbax
Senior Member
 
Iscritto dal: Apr 2007
Messaggi: 381
e volendo modificare il mio senza riscrivere tutto quel pezzo come posso fare?

cioè al poso di a[n] cosa dovrei metterci?

che significa fare un vettore di dimensioni fisse?
xbubbax è offline   Rispondi citando il messaggio o parte di esso
Old 18-07-2007, 18:16   #16
pisto
 
Messaggi: n/a
beh insomma ti è stato detto tutto quello che devi fare, adesso il codice lo butti giù tu, sei tu che devi imparare C no? devi trovare il modo per creare un array a runtime visto che il limite fino a quale cercare i numeri primi lo decidi a runtime, non stabilito in fase di compilazione.
guarda il codice di mapomapo

Ultima modifica di pisto : 18-07-2007 alle 18:18.
  Rispondi citando il messaggio o parte di esso
Old 18-07-2007, 19:35   #17
xbubbax
Senior Member
 
Iscritto dal: Apr 2007
Messaggi: 381
ho capito, non so se ci sarei arrivato però.. il mio mi sembrava perfetto
xbubbax è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


DJI Lito 1 e Lito X1 recensione: i nuovi droni per principianti che non si fanno mancare nulla DJI Lito 1 e Lito X1 recensione: i nuovi droni p...
Sony World Photography Awards 2026: i premiati, anche italiani, il punto sulla fotografia di oggi Sony World Photography Awards 2026: i premiati, ...
Una settimana con Hyundai Ioniq 5 N-Line: diverte e convince Una settimana con Hyundai Ioniq 5 N-Line: divert...
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...
iPhone Ultra, periodo di lancio conferma...
Un anno fa debuttava Clair Obscur:&...
Tutte le offerte sugli smartphone ora pi...
Tutte le offerte sui TV ora su Amazon: u...
Xbox Game Pass sarà disponibile a...
La serie HONOR 600 avrà presto un...
Mova Viax 250 in prova: il robot tagliae...
Fat e-bike per tutti: sconti Engwe, pi&u...
Google conferma l'arrivo della nuova ver...
Apple ha trovato il modo per abbassare i...
OpenAI vuole tassare l'AI per dare a tut...
MacBook Air 15'' con chip M4 a 1.199€ su...
Samsung Galaxy S25 Edge 12/512GB a 854€ ...
Super offerta sul portatile gaming Acer ...
Nanotubi di carbonio più conduttivi del ...
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:45.


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