Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Dark Perk Ergo e Sym provati tra wireless, software via browser e peso ridotto
Dark Perk Ergo e Sym provati tra wireless, software via browser e peso ridotto
be quiet! debutta nel settore mouse da gaming con Dark Perk Ergo e Dark Perk Sym: due modelli gemelli per specifiche, con polling rate di 8.000 Hz anche in wireless, sensore PixArt PAW3950 da 32.000 DPI e autonomia dichiarata fino a 110 ore. Nel test, a 8.000 Hz si arriva a circa 30 ore reali, con ricarica completa in un'ora e mezza
DJI RS 5: stabilizzazione e tracking intelligente per ogni videomaker
DJI RS 5: stabilizzazione e tracking intelligente per ogni videomaker
Analizziamo nel dettaglio DJI RS 5, l'ultimo arrivato della famiglia Ronin progettato per videomaker solisti e piccoli studi. Tra tracciamento intelligente migliorato e ricarica ultra rapida, scopriamo come questo gimbal eleva la qualità delle produzioni.
AMD Ryzen 7 9850X3D: Zen 5, 3D V-Cache e frequenze al top per il gaming
AMD Ryzen 7 9850X3D: Zen 5, 3D V-Cache e frequenze al top per il gaming
AMD Ryzen 7 9850X3D è la nuova CPU gaming di riferimento grazie alla 3D V-Cache di seconda generazione e frequenze fino a 5,6 GHz. Nei test offre prestazioni superiori a 9800X3D e 7800X3D, confermando la leadership AMD nel gaming su PC.
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 15-06-2011, 19:54   #1
mame83
Member
 
Iscritto dal: Nov 2010
Messaggi: 71
[c]inserire un nodo insolato ad un grafo con matrice di adiacenza

Ciao a tutti ho il seguente problema: voglio inserire un nodo isolato in un grafo rappresentato con matrice di adiacenza dinamica. Cioè la matrice dinamica[NxN] è rappresentata tramite un vettore dinamico[NxN].
Codice:
void INSERISCI_NODO(int n, int **vt)/*inserisce nodo isolato n esimo*/
{
 int i,j;
 int nuovi=(n+1)*(n+1);
 *vt=(int*)realloc(*vt,nuovi*sizeof(int));
 for (i=0; i<(n*(n+1)); i++)
   { 
    
    if ((i!=0)&&(i%n==0))
      {
       for (j=(((n+1)*(n+1))-1); j>i; j--)
           {
            (*vt)[j]=(*vt)[j-1];
           } 
       (*vt)[i]=0;
      } 
    }
 /*gli ultimi n elementi saranno 0 */
 for (j=i; j<((n+1)*(n+1)); j++)
    (*vt)[j]=0; 
 printf("vettore NUOVO NODO ISOLATO e' : \n");         
 for (i=0; i<((n+1)*(n+1)); i++)
   { 
     if((i!=0)&&(i%(n+1)==0))
        printf("  ");
     printf("%d ",(*vt)[i]);
   }  
 printf("\n");           

}
int main()
{
 int nodi,i;
  int *vet=NULL;
  printf("dammi il numero di nodi : \n");
  scanf("%d",&nodi);
  RIEMPI(nodi,&vet);
  printf("vettore INIZIALE e' : \n");
  for(i=0; i<(nodi*nodi); i++)
    {
     if((i!=0)&&(i%nodi==0))
       printf("  ");
     printf("%d ",vet[i]);
    } 
  printf("\n");
il vettore vet (dichiarato come puntatore ad interi) è riempito nella void riempi. Poi richiamo la void INSERISCI_NODO dove gli passerò il vettore [NxN] elementi che aggiungendo un nodo diventerà (riallocandolo)di (N+1)*(N+1) elementi.
Esempio se vet di 3 nodi è:
011 101 110
aggiungendo un elemento dovrebbe essere:
0110 1010 1100 0000
Invece il mio output è sbagliato.
Spero di essere stato chiaro e che qualcuno mi aiuti grazie.
mame83 è offline   Rispondi citando il messaggio o parte di esso
Old 16-06-2011, 17:11   #2
mame83
Member
 
Iscritto dal: Nov 2010
Messaggi: 71
ragazzi vi prego aiutatemi non so piu cosa fare.
mame83 è offline   Rispondi citando il messaggio o parte di esso
Old 17-06-2011, 09:57   #3
mame83
Member
 
Iscritto dal: Nov 2010
Messaggi: 71
alla fine ho trovato una soluzione semplice ma efficace. Allora metto un contatore che ogni n+1 elementi si ferma shifta verso destra gli elementi e pone vet[n+1*i]=0.
Codice:
void INSERISCI_NODO(int n, int **vt)/*inserisce nodo isolato n esimo*/
{
 int i,j;
 int cont=0;
 *vt=(int*)realloc(*vt,(n+1)*(n+1)*sizeof(int));
 for (i=0; i<(n*(n+1)); i++)/*gli ultimi n+1 elementi sono 0 */
   { 
    cont++;
    if (cont==(n+1))
      {
       for (j=((n*(n+1))-1); j>i; j--)
           {
            (*vt)[j]=(*vt)[j-1];
           } 
        (*vt)[i]=0;
        cont=0;
      } 
    }
 /*gli ultimi n elementi saranno 0 */
 for (j=i; j<((n+1)*(n+1)); j++)/*azzeriamo gli ultimi n+1 elementi*/
    (*vt)[j]=0; 
 printf("vettore NUOVO NODO ISOLATO e' : \n");         
 for (i=0; i<((n+1)*(n+1)); i++)
   { 
     if((i!=0)&&(i%(n+1)==0))
        printf("  ");
     printf("%d ",(*vt)[i]);
   }  
 printf("\n");           

}
che ne pensate???
mame83 è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Dark Perk Ergo e Sym provati tra wireless, software via browser e peso ridotto Dark Perk Ergo e Sym provati tra wireless, softw...
DJI RS 5: stabilizzazione e tracking intelligente per ogni videomaker DJI RS 5: stabilizzazione e tracking intelligent...
AMD Ryzen 7 9850X3D: Zen 5, 3D V-Cache e frequenze al top per il gaming AMD Ryzen 7 9850X3D: Zen 5, 3D V-Cache e frequen...
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 ...
Segway Navimow presenta la nuova gamma d...
Xiaomi SU7 Pro: l'ispezione dopo 265.000...
Nimbus Innovation Awards 2026: le miglio...
SSD Samsung contraffatto, ma Windows e C...
Enrique Lores, CEO e presidente di HP, l...
SoftBank e Intel preparano la 'memoria d...
Il blocco dei porno per i minori è...
AMD: i nuovi processori Zen 6 saranno (i...
Ancora aumenti per le schede video Radeo...
Sonos presenta Amp Multi a ISE 2026: il ...
Una funzione esclusiva dei Pixel potrebb...
La Cina vieta ufficialmente le maniglie ...
HP e lavoro ibrido: le nuove cuffie Poly...
MSI sta lavorando a un dissipatore ottim...
27 offerte Amazon, le prime 5 in elenco ...
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: 05:23.


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