Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Le soluzioni FSP per il 2026: potenza e IA al centro
Le soluzioni FSP per il 2026: potenza e IA al centro
In occasione del Tech Tour 2025 della European Hardware Association abbiamo incontrato a Taiwan FSP, azienda impegnata nella produzione di alimentatori, chassis e soluzioni di raffreddamento tanto per clienti OEM come a proprio marchio. Potenze sempre più elevate negli alimentatori per far fronte alle necessità delle elaborazioni di intelligenza artificiale.
AWS annuncia European Sovereign Cloud, il cloud sovrano per convincere l'Europa
AWS annuncia European Sovereign Cloud, il cloud sovrano per convincere l'Europa
AWS è il principale operatore di servizi cloud al mondo e da tempo parla delle misure che mette in atto per garantire una maggiore sovranità alle organizzazioni europee. L'azienda ha ora lanciato AWS European Sovereign Cloud, una soluzione specificamente progettata per essere separata e distinta dal cloud "normale" e offrire maggiori tutele e garanzie di sovranità
Redmi Note 15 Pro+ 5G: autonomia monstre e display luminoso, ma il prezzo è alto
Redmi Note 15 Pro+ 5G: autonomia monstre e display luminoso, ma il prezzo è alto
Xiaomi ha portato sul mercato internazionale la nuova serie Redmi Note, che rappresenta spesso una delle migliori scelte per chi non vuole spendere molto. Il modello 15 Pro+ punta tutto su una batteria capiente e su un ampio display luminoso, sacrificando qualcosa in termini di potenza bruta e velocità di ricarica
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 18-07-2007, 09: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, 09: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, 09: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, 10: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, 10: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, 10: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, 10: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 19:08.
Furla è offline   Rispondi citando il messaggio o parte di esso
Old 18-07-2007, 14: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, 15: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, 15: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, 15: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 16:08.
  Rispondi citando il messaggio o parte di esso
Old 18-07-2007, 15: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, 16: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 16:17.
  Rispondi citando il messaggio o parte di esso
Old 18-07-2007, 17: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, 18: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, 19: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 19:18.
  Rispondi citando il messaggio o parte di esso
Old 18-07-2007, 20: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


Le soluzioni FSP per il 2026: potenza e IA al centro Le soluzioni FSP per il 2026: potenza e IA al ce...
AWS annuncia European Sovereign Cloud, il cloud sovrano per convincere l'Europa AWS annuncia European Sovereign Cloud, il cloud ...
Redmi Note 15 Pro+ 5G: autonomia monstre e display luminoso, ma il prezzo è alto Redmi Note 15 Pro+ 5G: autonomia monstre e displ...
HONOR Magic 8 Pro: ecco il primo TOP del 2026! La recensione HONOR Magic 8 Pro: ecco il primo TOP del 2026! L...
Insta360 Link 2 Pro e 2C Pro: le webcam 4K che ti seguono, anche con gimbal integrata Insta360 Link 2 Pro e 2C Pro: le webcam 4K che t...
I food truck a New York ora si alimentan...
Meta blocca i chatbot AI con personalit&...
Resident Evil Code: Veronica, il Remake ...
Allenatore esonerato a causa di ChatGPT?...
Il mercato degli SSD è in salita:...
Offerte Dell su Amazon: 4 portatili pote...
Richard Stallman spara a zero su intelli...
C'è anche un Ripetitore Wi-Fi sot...
Biostampa 3D: scienziati creano tessuto ...
Adesso puoi comprare gli occhiali smart ...
Changan CS75 Plus entra nel Guinness: sa...
Prime foto della McLaren MCL40: bellissi...
Una manna per gli allergici: torna a 79€...
Blink a prezzo minimo storico: Mini 2K+ ...
Un professore tedesco perde due anni di ...
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: 12:51.


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