Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Recensione Samsung Galaxy S26+: sfida l'Ultra, ma ha senso di esistere?
Recensione Samsung Galaxy S26+: sfida l'Ultra, ma ha senso di esistere?
Equilibrio e potenza definiscono il Samsung Galaxy S26+, un flagship che sfida la variante Ultra e la fascia alta del mercato con il primo processore mobile a 2nm. Pur mantenendo l'hardware fotografico precedente, lo smartphone brilla per un display QHD+ da 6,7 pollici d'eccellenza, privo però del trattamento antiriflesso dell'Ultra, e per prestazioni molto elevate. Completano il quadro la ricarica wireless a 20W e, soprattutto, un supporto software settennale
Zeekr X e 7X provate: prezzi, autonomia fino a 615 km e ricarica in 13 minuti
Zeekr X e 7X provate: prezzi, autonomia fino a 615 km e ricarica in 13 minuti
Zeekr sbarca ufficialmente in Italia con tre modelli elettrici premium, X, 7X e 001, distribuiti da Jameel Motors su una rete di 52 punti vendita già attivi. La Zeekr X parte da 39.900 euro, la 7X da 54.100: piattaforma a 800V, chip Snapdragon di ultima generazione, ricarica ultraveloce e un'autonomia dichiarata fino a 615 km WLTP. Le prime consegne sono previste a metà aprile
Marathon: arriva il Fortnite hardcore
Marathon: arriva il Fortnite hardcore
Marathon è il titolo multiplayer competitivo del momento. Ecco quali sono le caratteristiche di gioco principali, insieme alle nostre prime considerazioni dopo qualche "run" nell'extraction shooter di Bungie
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 30-08-2004, 20:11   #1
xber-gigi
Senior Member
 
L'Avatar di xber-gigi
 
Iscritto dal: Jun 2003
Città: Pianeta Terra
Messaggi: 281
Algoritmo somma vettori sparsi

algoritmo di somma di due vettori sparsi, memorizzati nel formato a coordinate. Nei test usare vettori di ordine 100, 200, 500, in cui solo il 5% degli elementi è non nullo. Generare a caso sia il valore di un elemento non nullo (un intero in 0,1,..,10) sia il suo indice. Usare la function rand() in <stdlib.h> per generare numeri casuali; per esempio, se numero_casuale è un int, la chiamata numero_casuale=rand()%11; genera un numero casuale intero (distribuzione uniforme) nell’insieme (0,1,2,..,10).

Ragazzi per favore potreste spiegarmi cosa richiede questo esercizio??? E' molto importante!!!

Ho realizzato il programma con due array creati casualmente ma mi hanno detto che non va bene in quanto devono essere vettori sparsi.
Per favore potreste aiutarmi???
__________________
LE AVVENTURE DI AL METALLER E CHELA FDM - IL FOTOROMANZO TRASH!
When I'm walking a dark road... I am a man who walks alone...
xber-gigi è offline   Rispondi citando il messaggio o parte di esso
Old 30-08-2004, 20:21   #2
cionci
Senior Member
 
L'Avatar di cionci
 
Iscritto dal: Apr 2000
Città: Vicino a Montecatini(Pistoia) Moto:Kawasaki Ninja ZX-9R Scudetti: 29
Messaggi: 53971
Sparso significa che ci sono molti elemnti pari a 0... In questo caso ti da la percentuale degli elementi che devono essere diversi da zero...

In pratica fai un test sulla percentuale del 5% ed in tal caso generi un numero > 0...
cionci è offline   Rispondi citando il messaggio o parte di esso
Old 30-08-2004, 20:28   #3
xber-gigi
Senior Member
 
L'Avatar di xber-gigi
 
Iscritto dal: Jun 2003
Città: Pianeta Terra
Messaggi: 281
Io ho fatto nel seguente modo che ora incollo.
Mi è stato detto che non ho fatto un corretto uso del formato a coordinate e che quindi devo riprogettare completamente tutta la parte.
Per favore aiutatemi!!! Fatemi capire dove ho sbagliato!!!

#include <stdio.h>
#include <stdlib.h>

void main ()

{
int vett1[1000], vett2[1000];
int n,i,nonulli,numero_casuale,posizione,prod_scalare;
printf ("Indicare la grandezza dei vettori: ");
scanf ("%d",&n);

/* CALCOLO DEL 5% DELLA GRANDEZZA DEL VETTORE*/

nonulli = (n * 5) /100;

/* INSERISCE IL VALORE 0 AD OGNI IDICE DEL VETTORE*/

for (i=0;i<n;i++)
{
vett1[i] = 0;
}
for (i=0;i<n;i++)
{
vett2[i] = 0;
}

/* ATTRIBUISCE IN POSIZIONI CASUALI NUMERI CASUALI*/

for (i=1;i<=nonulli;i++)
{
numero_casuale=1+rand()%10;
posizione=rand()%(n-1);

/* SE LA POSIZIONE USCITA è GIà OCCUPATA DA UN INTERO, UTILIZZA LA PROSSIMA DIVERSA DA ZERO */

while (vett1[posizione]!=0)
{
posizione=(posizione+1) %n;
}

vett1[posizione]=numero_casuale;
}

for (i=1;i<=nonulli;i++)
{
numero_casuale=1+rand()%10;
posizione=rand()%(n-1);

while (vett2[posizione]!=0)
{
posizione=(posizione+1) %n ;
}

vett2[posizione]=numero_casuale;
}

/* STAMPA DEI VETTORI*/

printf ("STAMPA VETTORE NUMERO UNO\n");
for (i=0;i<n;i++)
{
printf ("%d ", vett1[i]);
}
printf ("\n\n");

printf ("STAMPA VETTORE NUMERO DUE\n");
for (i=0;i<n;i++)
{
printf ("%d ", vett2[i]);
}
__________________
LE AVVENTURE DI AL METALLER E CHELA FDM - IL FOTOROMANZO TRASH!
When I'm walking a dark road... I am a man who walks alone...
xber-gigi è offline   Rispondi citando il messaggio o parte di esso
Old 31-08-2004, 07:56   #4
cionci
Senior Member
 
L'Avatar di cionci
 
Iscritto dal: Apr 2000
Città: Vicino a Montecatini(Pistoia) Moto:Kawasaki Ninja ZX-9R Scudetti: 29
Messaggi: 53971
Mi sembra che sia fatto come richiedeva il testo...ci sono però alcune cose che potevi compattare molto di più...ad esempio:
Codice:
#include <stdio.h>
#include <stdlib.h>

void main ()

{
	int vett1[1000], vett2[1000];
	int n,i,nonulli,numero_casuale,posizione,prod_scalare;
		printf ("Indicare la grandezza dei vettori: ");
	scanf ("%d",&n);
	
	/* CALCOLO DEL 5% DELLA GRANDEZZA DEL VETTORE*/

	nonulli = (n * 5) /100;
	
	/* INSERISCE IL VALORE 0 AD OGNI IDICE DEL VETTORE*/
	
	for (i=0;i<n;i++)
		vett2[i] = vett1[i] = 0;
	
	/* ATTRIBUISCE IN POSIZIONI CASUALI NUMERI CASUALI*/
	
	for (i=1;i<=nonulli;i++)
	{
		numero_casuale=1+rand()%10;
		posizione=rand()%(n-1);
		
		/* SE LA POSIZIONE USCITA è GIà OCCUPATA DA UN INTERO, UTILIZZA LA PROSSIMA DIVERSA DA ZERO */
		
		while (vett1[posizione]!=0)
		{ 
			posizione=(posizione+1) %n;
		}

		vett1[posizione]=numero_casuale;

		numero_casuale=1+rand()%10;
		posizione=rand()%(n-1);

		while (vett2[posizione]!=0)
		{ 
			posizione=(posizione+1) %n ;
		}

		vett2[posizione]=numero_casuale;
	}
	
	/* STAMPA DEI VETTORI*/
	
	printf ("STAMPA VETTORE NUMERO UNO\n");
	for (i=0;i<n;i++)
	{
		printf ("%d ", vett1[i]);
	}
	printf ("\n\n");
	
	printf ("STAMPA VETTORE NUMERO DUE\n");
	for (i=0;i<n;i++)
	{
		printf ("%d ", vett2[i]);
	}
}
cionci è offline   Rispondi citando il messaggio o parte di esso
Old 31-08-2004, 07:57   #5
cionci
Senior Member
 
L'Avatar di cionci
 
Iscritto dal: Apr 2000
Città: Vicino a Montecatini(Pistoia) Moto:Kawasaki Ninja ZX-9R Scudetti: 29
Messaggi: 53971
Ora che ci penso...che intende per "formato a coordinate" ?
cionci è offline   Rispondi citando il messaggio o parte di esso
Old 31-08-2004, 10:19   #6
xber-gigi
Senior Member
 
L'Avatar di xber-gigi
 
Iscritto dal: Jun 2003
Città: Pianeta Terra
Messaggi: 281
Per le matrici o i vettori formati per la maggiorparte da zero è preferibile usare il criterio di memorizzazione a coordinate.
Questo è formato da tre array 1D.
Il primo contiene tutti gli elementi non nulli della matrice (o vettore).
Il secondo contiene l'indice della colonna.
Il terzo contiene l'indice della riga.
__________________
LE AVVENTURE DI AL METALLER E CHELA FDM - IL FOTOROMANZO TRASH!
When I'm walking a dark road... I am a man who walks alone...
xber-gigi è offline   Rispondi citando il messaggio o parte di esso
Old 31-08-2004, 10:47   #7
cionci
Senior Member
 
L'Avatar di cionci
 
Iscritto dal: Apr 2000
Città: Vicino a Montecatini(Pistoia) Moto:Kawasaki Ninja ZX-9R Scudetti: 29
Messaggi: 53971
Ah...ok... Questa cosa non l'hai fatta per niente nel tuo programma...
cionci è offline   Rispondi citando il messaggio o parte di esso
Old 31-08-2004, 11:28   #8
xber-gigi
Senior Member
 
L'Avatar di xber-gigi
 
Iscritto dal: Jun 2003
Città: Pianeta Terra
Messaggi: 281
Si ma cmq non so proprio come proseguire ora!!!
Come dichiaro l'array se non so quanto è lungo?!?!?
Devo immettere io la grandezza del vettore!
Brother of true metal! Help me!!!
__________________
LE AVVENTURE DI AL METALLER E CHELA FDM - IL FOTOROMANZO TRASH!
When I'm walking a dark road... I am a man who walks alone...
xber-gigi è offline   Rispondi citando il messaggio o parte di esso
Old 31-08-2004, 11:41   #9
cionci
Senior Member
 
L'Avatar di cionci
 
Iscritto dal: Apr 2000
Città: Vicino a Montecatini(Pistoia) Moto:Kawasaki Ninja ZX-9R Scudetti: 29
Messaggi: 53971
Nemmeno prima sapevi quanto era lungo...eppure la dimensione l'hai data

Fai lo stesso discorso di prima oppure procedi con l'allocazione dinamica che non so se hai già fatto...
cionci è offline   Rispondi citando il messaggio o parte di esso
Old 31-08-2004, 11:42   #10
cionci
Senior Member
 
L'Avatar di cionci
 
Iscritto dal: Apr 2000
Città: Vicino a Montecatini(Pistoia) Moto:Kawasaki Ninja ZX-9R Scudetti: 29
Messaggi: 53971
Ah...ricordati che non hai una matrice...quindi non ti serve un vettore in meno...
cionci è offline   Rispondi citando il messaggio o parte di esso
Old 01-09-2004, 10:35   #11
xber-gigi
Senior Member
 
L'Avatar di xber-gigi
 
Iscritto dal: Jun 2003
Città: Pianeta Terra
Messaggi: 281
Ti rigrazio per le rispote!

Sapete per caso la formula per la somma di due vettori?!?!??
__________________
LE AVVENTURE DI AL METALLER E CHELA FDM - IL FOTOROMANZO TRASH!
When I'm walking a dark road... I am a man who walks alone...
xber-gigi è offline   Rispondi citando il messaggio o parte di esso
Old 01-09-2004, 11:49   #12
xber-gigi
Senior Member
 
L'Avatar di xber-gigi
 
Iscritto dal: Jun 2003
Città: Pianeta Terra
Messaggi: 281
Sono proprio in difficoltà!!!
Aiuto!!!

Ora che genero l'array con le coordinate attraverso una rand come faccio a vedere se la stessa coordinata non mi è uscita prima??? Ovvero che non mi escano due numeri uguali nello stesso array?!?!?!

Per favore help!!! Sto entrando in pallone con la testa!!!
__________________
LE AVVENTURE DI AL METALLER E CHELA FDM - IL FOTOROMANZO TRASH!
When I'm walking a dark road... I am a man who walks alone...
xber-gigi è offline   Rispondi citando il messaggio o parte di esso
Old 01-09-2004, 14:58   #13
cionci
Senior Member
 
L'Avatar di cionci
 
Iscritto dal: Apr 2000
Città: Vicino a Montecatini(Pistoia) Moto:Kawasaki Ninja ZX-9R Scudetti: 29
Messaggi: 53971
Ci sono diversi modi...

1) Estrai un nuovo nume3ro fino a quando non esiste all'interno delle coordinate (soluzione non buone secondo me)

2) Estrai un numero...fai la scansione del vettore e verifichi se il numero è già presente fra le coordinate... Se è presente lo incrementi di uno (modulo N)... Riparti a fare la scansione... Così via fino a quando verifichi che il numero non è presente fra le coordinate...Ogni volta devi diminuire la qantità di numeri da cui fai l'estrazione (devi diminuire K di rand() % K + 1)...
cionci è offline   Rispondi citando il messaggio o parte di esso
Old 01-09-2004, 20:16   #14
xber-gigi
Senior Member
 
L'Avatar di xber-gigi
 
Iscritto dal: Jun 2003
Città: Pianeta Terra
Messaggi: 281
Non ci ho capito molto
che struttura interativa dovrei utilizzare???
Help!
__________________
LE AVVENTURE DI AL METALLER E CHELA FDM - IL FOTOROMANZO TRASH!
When I'm walking a dark road... I am a man who walks alone...
xber-gigi è offline   Rispondi citando il messaggio o parte di esso
Old 01-09-2004, 20:29   #15
cionci
Senior Member
 
L'Avatar di cionci
 
Iscritto dal: Apr 2000
Città: Vicino a Montecatini(Pistoia) Moto:Kawasaki Ninja ZX-9R Scudetti: 29
Messaggi: 53971
Per il secondo:


numero_estratto = 1 + rand() % (N-1);


do {

for(i=0; i< quantità_estratti; ++i)
{
se vet[i] == numero_estratto allora 1 + (numero_estratto % (MAX-1));
}

} while(non ho aumentato il numero estratto);

N = N-1;

E riparti da capo...

Ultima modifica di cionci : 01-09-2004 alle 20:32.
cionci è offline   Rispondi citando il messaggio o parte di esso
Old 02-09-2004, 11:33   #16
xber-gigi
Senior Member
 
L'Avatar di xber-gigi
 
Iscritto dal: Jun 2003
Città: Pianeta Terra
Messaggi: 281
Dopo un intera giornata credendo di impazzire sono arrivato a questa conclusione. Credi che vada bene???
Praticamente nel momento in cui trova che il numero pescato casualmente è già nell'array, ripete l'estrazione di un nuovo numero casuale finchè questo non è diverso da quelli già presenti.
Cosa ne dici??? Cè qualche bug secondo te???

/*GENERAZIONE DELLE COORDINATE*/

for (i=0;i<nonulli;i++)
{
do
{
numero_cas = rand()%n;
y=-1;
x=0;

do
{
y=y+1
}
while (coordinate1[y]!=numero || y==nonnulli);

if (coordinate1[y] == numero_cas)
{
x=1;
}
}
while (x==1);
coordinate1[i] = numero_cas;
}
__________________
LE AVVENTURE DI AL METALLER E CHELA FDM - IL FOTOROMANZO TRASH!
When I'm walking a dark road... I am a man who walks alone...
xber-gigi è offline   Rispondi citando il messaggio o parte di esso
Old 02-09-2004, 20:59   #17
cionci
Senior Member
 
L'Avatar di cionci
 
Iscritto dal: Apr 2000
Città: Vicino a Montecatini(Pistoia) Moto:Kawasaki Ninja ZX-9R Scudetti: 29
Messaggi: 53971
Sbagliato...questo potrebbe portare anche al blocco del programma... Ti ho scritto sopra cosa fare... C'è qualcosa che non ti torna ?
cionci è offline   Rispondi citando il messaggio o parte di esso
Old 03-09-2004, 11:07   #18
xber-gigi
Senior Member
 
L'Avatar di xber-gigi
 
Iscritto dal: Jun 2003
Città: Pianeta Terra
Messaggi: 281
Ok sono riuscito a creare le coordinate.
Ma ora la somma?
Come sommo i due array?
__________________
LE AVVENTURE DI AL METALLER E CHELA FDM - IL FOTOROMANZO TRASH!
When I'm walking a dark road... I am a man who walks alone...
xber-gigi è offline   Rispondi citando il messaggio o parte di esso
Old 03-09-2004, 11:36   #19
xber-gigi
Senior Member
 
L'Avatar di xber-gigi
 
Iscritto dal: Jun 2003
Città: Pianeta Terra
Messaggi: 281
Pensavo che devo lavorare anche sulle coordinate del risultato?!?
Questi maledetti vettori a coordinate mi stanno facendo impazzire!!!
Lo avevo già fatto utilizzando due vettori incizzati normalmente e ci avevo messo 5 minuti a realizzarlo!!!
__________________
LE AVVENTURE DI AL METALLER E CHELA FDM - IL FOTOROMANZO TRASH!
When I'm walking a dark road... I am a man who walks alone...
xber-gigi è offline   Rispondi citando il messaggio o parte di esso
Old 03-09-2004, 13:57   #20
cionci
Senior Member
 
L'Avatar di cionci
 
Iscritto dal: Apr 2000
Città: Vicino a Montecatini(Pistoia) Moto:Kawasaki Ninja ZX-9R Scudetti: 29
Messaggi: 53971
Allora...per la somma è semplice...

Copia il contenuto del vettore "uno" nel vettore del risultato (fai una copia elemento per elemento dei dati e delle coordinate)...

Comincia a scorrere il vettore "due"... Per ogni elemento delle coordinate del vettore "due": se la coordinata in questione esiste anche nelle coordinate del risultato allora somma il dato corrispondente del vettore "due" al dato corrispondente alla stessa cooridinata nel vettore del risultato...altrimenti aggiungi una nuova coordinata e un nuovo dato al risultato...
cionci è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Recensione Samsung Galaxy S26+: sfida l'Ultra, ma ha senso di esistere? Recensione Samsung Galaxy S26+: sfida l'Ultra, m...
Zeekr X e 7X provate: prezzi, autonomia fino a 615 km e ricarica in 13 minuti Zeekr X e 7X provate: prezzi, autonomia fino a 6...
Marathon: arriva il Fortnite hardcore Marathon: arriva il Fortnite hardcore
HP Imagine 2026: abbiamo visto HP IQ all’opera, ecco cosa può (e non può) fare HP Imagine 2026: abbiamo visto HP IQ all’opera, ...
PNY RTX 5080 Slim OC, sembra una Founders Edition ma non lo è PNY RTX 5080 Slim OC, sembra una Founders Editio...
Intel riacquista la Fab 34 in Irlanda, u...
SpaceX ha lanciato la missione Transport...
Occhiali smart in affitto: la nuova stra...
L'aeroplano supersonico ''silenzioso'' N...
Il primo chip a 2 nm di MediaTek sarà a...
Blue Origin lancerà il satellite ...
Roscosmos torna a lanciare capsule verso...
La connettività satellitare anche sui di...
Astronauta italiano sul suolo lunare gra...
Senza formazione ai dipendenti l'IA non ...
Google rende disponibile l'opzione per i...
Oracle licenzia migliaia di persone con ...
Il semaforo bianco sta arrivando: cos'è,...
FRITZ!Repeater 2700 disponibile su Amazo...
Xiaomi TV A Pro: QLED 4K da 65'' con Goo...
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: 23:20.


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