Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Il cuore digitale di F1 a Biggin Hill: l’infrastruttura Lenovo dietro la produzione media
Il cuore digitale di F1 a Biggin Hill: l’infrastruttura Lenovo dietro la produzione media
Nel Formula 1 Technology and Media Centre di Biggin Hill, la velocità delle monoposto si trasforma in dati, immagini e decisioni in tempo reale grazie all’infrastruttura Lenovo che gestisce centinaia di terabyte ogni weekend di gara e collega 820 milioni di spettatori nel mondo
DJI Osmo Mobile 8: lo stabilizzatore per smartphone con tracking multiplo e asta telescopica
DJI Osmo Mobile 8: lo stabilizzatore per smartphone con tracking multiplo e asta telescopica
Il nuovo gimbal mobile DJI evolve il concetto di tracciamento automatico con tre modalità diverse, un modulo multifunzionale con illuminazione integrata e controlli gestuali avanzati. Nel gimbal è anche presente un'asta telescopica da 215 mm con treppiede integrato, per un prodotto completo per content creator di ogni livello
Recensione Pura 80 Pro: HUAWEI torna a stupire con foto spettacolari e ricarica superveloce
Recensione Pura 80 Pro: HUAWEI torna a stupire con foto spettacolari e ricarica superveloce
Abbiamo provato il nuovo HUAWEI Pura 80 Pro. Parliamo di uno smartphone che è un vero capolavoro di fotografia mobile, grazie ad un comparto completo in tutto e per tutto, In questa colorazione ci è piaciuto molto, ma i limiti hardware e software, seppur in netto miglioramento, ci sono ancora. Ma HUAWEI ha fatto davvero passi da gigante per questa nuova serie Pura 80. Buona anche l'autonomia e soprattutto la ricarica rapida sia cablata che wireless, velocissima.
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 05-10-2007, 18:51   #1
Tony Hak
Senior Member
 
L'Avatar di Tony Hak
 
Iscritto dal: Jun 2005
Città: Napoli
Messaggi: 1661
c aiuto heap

ciao .
Ho il seguente problema...
inserisco una serie di numeri in un array la cui dimensione la stabilisco io. Dopo di che da questo Array mi creo un Heap binario. Vado a cercare nell'array modificato come fosse un heap l'elemento che voglio cancellare. Se esiste allora lo cancello andando a sostituire l'elemento stesso con l'ultimo elemento dell'array e ridimensionando l'arraysize (arraysize -= 1). Quindi ordino gli elementi con l'heapsort e stampo i numeri contenuti tranne naturalmente l'ultimo elemento che è quello individuato e cancellato..ma ..la funzione per cancellare nn funziona.. dove sbaglio ? sono nuovo in C e nn riesco ancora ad entrare nella logica. Potete aiutarmi anche magari dandomi delle dritte su questo programma ? grazie mille ..

codice

#include <stdio.h>
#include <stdlib.h>
#define MAX 20
int arraysize,heapsize,tot;
int left(int i)
{
return 2*i+1;
}

int right(int i)
{
return 2*i+2;
}

int p(int i)
{
return (i-1)/2;
}

void swap(int A[MAX], int i, int j)
{
int temp = A[i];
A[i] = A[j];
A[j] = temp;
}

void heapfy (int A[MAX], int i);
void buildheap(int A[MAX]);
int ricerca (int A[MAX],int el);
void cancella (int A[MAX],int ind);
void heapsort(int A[MAX]);

void heapfy(int A[MAX], int i)
{
int l,r,largest;
l=left(i);
r=right(i);
if (l<heapsize && A[l]>A[i])
largest=l;
else
largest=i;
if (r<heapsize && A[r] > A[largest])
largest=r;
if (largest != i )
{
swap (A,i,largest);
heapfy(A,largest);
}
}


void buildheap(int A[MAX])
{
int i,el;
heapsize=arraysize;
for (i=arraysize/2;i>=0;i--)
heapfy(A,i);
printf("\n inserisci l'elemento da cancellare: ");
scanf ("%d",&el);
ricerca(A,el);

}

int ricerca (int A[MAX],int el)
{
int i,x ;
i=x=0;
while ((i<= MAX) && (x=0))
{
if (el <= A[i])
{
if (A[i] = el)
{
cancella (A,i);
x=1;
}
else
i+=1;
}
else
x=1;
}
}

void cancella (int A[MAX],int ind)
{

swap (A,ind,arraysize);
arraysize -=1;

}





void heapsort(int A[MAX])
{
int i;
buildheap(A);
for (i=arraysize-1;i>=1; i--)
{
swap (A,0,i);
heapsize--;
heapfy(A,0);
}
}

main()
{
int A[MAX],k;
printf("\n quanti elementi deve contenere l'array?");
scanf("%d",&tot);
while (tot>MAX)
{
printf("\n max 20 elementi: ");
scanf ("%d",&tot);
}
for (k=0; k<tot; k++)
{
printf("\n inserire il %d° elemento: ",k+1);
scanf("%d",&A[k]);
}
heapsize=arraysize=tot;

heapsort(A);
printf("\n array ordinato:");
for (k=0;k<arraysize;k++)
printf("%d",A[k]);
scanf("%d");
system ("\n pause");
}
__________________
Tony Hak è offline   Rispondi citando il messaggio o parte di esso
Old 05-10-2007, 21:34   #2
marko.fatto
Senior Member
 
L'Avatar di marko.fatto
 
Iscritto dal: Jul 2007
Messaggi: 499
Ti dispiacerebbe utilizzare i tag code?
Sarebbe molto più leggibile...
__________________
marko.fatto è offline   Rispondi citando il messaggio o parte di esso
Old 05-10-2007, 21:41   #3
Tony Hak
Senior Member
 
L'Avatar di Tony Hak
 
Iscritto dal: Jun 2005
Città: Napoli
Messaggi: 1661
Quote:
Originariamente inviato da marko.fatto Guarda i messaggi
Ti dispiacerebbe utilizzare i tag code?
Sarebbe molto più leggibile...
cos'e' il tag code ?cosi' ? (vedi allegato)
Allegati
File Type: zip heapsorteser.zip (890 Bytes, 3 visite)
__________________

Ultima modifica di Tony Hak : 05-10-2007 alle 21:55.
Tony Hak è offline   Rispondi citando il messaggio o parte di esso
Old 05-10-2007, 21:46   #4
marko.fatto
Senior Member
 
L'Avatar di marko.fatto
 
Iscritto dal: Jul 2007
Messaggi: 499
Basta scrivere il codice all'interno di {CODE}{/CODE} (con le parentesi quadre al posto delle graffe)
Es:
Codice:
questo è del codice
__________________
marko.fatto è offline   Rispondi citando il messaggio o parte di esso
Old 05-10-2007, 21:57   #5
Tony Hak
Senior Member
 
L'Avatar di Tony Hak
 
Iscritto dal: Jun 2005
Città: Napoli
Messaggi: 1661
guarda ci ho provato ma nn va .. .cmq ti ho allegato il file .. .. grazie della pazienza..ora pero' devo staccare perche' sto avendo problemi di occhi rossi .. grazie mille !
__________________

Ultima modifica di Tony Hak : 05-10-2007 alle 22:03.
Tony Hak è offline   Rispondi citando il messaggio o parte di esso
Old 05-10-2007, 22:19   #6
Tony Hak
Senior Member
 
L'Avatar di Tony Hak
 
Iscritto dal: Jun 2005
Città: Napoli
Messaggi: 1661
Codice:
#include <stdio.h>
#include <stdlib.h>
#define MAX 20
int arraysize,heapsize,tot;
int left(int i) 
{
    return 2*i+1;
}

int right(int i) 
{
    return 2*i+2;
}

int p(int i) 
{
    return (i-1)/2;
}

void swap(int A[MAX], int i, int j)
     {
              int temp = A[i];
              A[i] = A[j];
              A[j] = temp;
     }

void heapfy (int A[MAX], int i);
void buildheap(int A[MAX]);
int ricerca (int A[MAX],int el);
void cancella (int A[MAX],int ind);
void heapsort(int A[MAX]);

void heapfy(int A[MAX], int i)
{
     int l,r,largest;
     l=left(i);
     r=right(i);
     if (l<heapsize && A[l]>A[i])
     largest=l;
     else
     largest=i;
     if (r<heapsize && A[r] > A[largest])
     largest=r;
     if (largest != i )
     {
                 swap (A,i,largest);
                 heapfy(A,largest);
     }
}


void buildheap(int A[MAX])
{
   int i,el;
   heapsize=arraysize;
   for (i=arraysize/2;i>=0;i--)
   heapfy(A,i);
   printf("\n inserisci l'elemento da cancellare: ");
      scanf ("%d",&el);
   ricerca(A,el);

}

int ricerca (int A[MAX],int el)
{
    int i,x ;
    i=x=0;
    while  ((i<= MAX) && (x=0))
    {
           if (el <= A[i])
           {
                  if (A[i] = el) 
                  {
                          cancella (A,i);
                          x=1;
                  }
                  else
                      i+=1;
           }
           else
               x=1;
    }
}

void cancella (int A[MAX],int ind)
{
   
   swap (A,ind,arraysize);
  arraysize -=1;

} 
           
    
    
    

void heapsort(int A[MAX])
{
     int i;
     buildheap(A);
     for (i=arraysize-1;i>=1; i--)
     {
         swap (A,0,i);
         heapsize--;
         heapfy(A,0);
     }
}

main()
{
      int A[MAX],k;
      printf("\n quanti elementi deve contenere l'array?");
      scanf("%d",&tot);
      while (tot>MAX)
            {
                     printf("\n max 20 elementi: ");
                     scanf ("%d",&tot);
            }
      for (k=0; k<tot; k++)
      {
          printf("\n inserire il %d° elemento: ",k+1);
          scanf("%d",&A[k]);
      }
      heapsize=arraysize=tot;
 
      heapsort(A);
      printf("\n array ordinato:");
      for (k=0;k<arraysize;k++)
      printf("%d",A[k]);
      scanf("%d");
      system ("\n pause");
}
ci sono riuscito ... mettevo le parentesi graffe ( ah ,la stanchezza hihi! )
__________________
Tony Hak è offline   Rispondi citando il messaggio o parte di esso
Old 05-10-2007, 22:38   #7
marko.fatto
Senior Member
 
L'Avatar di marko.fatto
 
Iscritto dal: Jul 2007
Messaggi: 499
Codice:
int ricerca (int A[MAX],int el)
{
    int i,x ;
    i=x=0;
    while  ((i<= MAX) && (x=0))
    {
           if (el <= A[i])
           {
                  if (A[i] = el) 
                  {
                          cancella (A,i);
                          x=1;
                  }
                  else
                      i+=1;
           }
           else
               x=1;
    }
}
Intanto due errori sono qui... nella condizione del while è x==0 e non x=0 ... Idem nell'if A[i]==el
__________________
marko.fatto è offline   Rispondi citando il messaggio o parte di esso
Old 05-10-2007, 23:38   #8
Tony Hak
Senior Member
 
L'Avatar di Tony Hak
 
Iscritto dal: Jun 2005
Città: Napoli
Messaggi: 1661
ok .. dmn li correggo e provo a farlo girare... .. il fatto è che ho sempre programmato in pascal :P

ps ... la x inzialmente doveva essere una flag booleana..ma nn so come si dichiara il tipo boolean in C .. .
__________________
Tony Hak è offline   Rispondi citando il messaggio o parte di esso
Old 05-10-2007, 23:52   #9
marko.fatto
Senior Member
 
L'Avatar di marko.fatto
 
Iscritto dal: Jul 2007
Messaggi: 499
Quote:
Originariamente inviato da Tony Hak Guarda i messaggi
ps ... la x inzialmente doveva essere una flag booleana..ma nn so come si dichiara il tipo boolean in C .. .
in C semplicemente non c'è...
__________________
marko.fatto è offline   Rispondi citando il messaggio o parte di esso
Old 06-10-2007, 00:22   #10
qwerty86
Senior Member
 
L'Avatar di qwerty86
 
Iscritto dal: Jun 2007
Messaggi: 1232
Quote:
Originariamente inviato da marko.fatto Guarda i messaggi
in C semplicemente non c'è...
puoi ovviare dichiarando una variabile di tipo intero , e assegnarli 0 o 1, rispettivamente per False e True.
__________________
Cpu: Amd 64 X2 5200+ - Mobo:M2N32SLI DELUXE - Ram: Corsair xms2 800 mhz kit 4gb - SK Video: Gaiward GTS250 - Ali : Enermax Liberty 500 Wat - Mast DVD: 2 Nec AD-5170A - Case : Thermaltake Armor+ - Dissipatore: Thermaltake V1 Notebook: Sony Vaio VGN-Fe21M-Pda: Htc Diamond |Il mio sito|Flickr| Stanco del solito forum? Vieni a parlare di fotografia su Fotoni
qwerty86 è offline   Rispondi citando il messaggio o parte di esso
Old 06-10-2007, 08:39   #11
Tony Hak
Senior Member
 
L'Avatar di Tony Hak
 
Iscritto dal: Jun 2005
Città: Napoli
Messaggi: 1661
eheh .. come avevo pensato di fare...ua ma davvero nn si possono dichiarare boolean ? ...cacchio ! cmq ora provo il programma cambiando quelle cose ...
__________________
Tony Hak è offline   Rispondi citando il messaggio o parte di esso
Old 06-10-2007, 08:42   #12
Tony Hak
Senior Member
 
L'Avatar di Tony Hak
 
Iscritto dal: Jun 2005
Città: Napoli
Messaggi: 1661
niente... nn va ... help col dev c++ come posso vedere l'esecuzione del programma passo per passo ?
__________________

Ultima modifica di Tony Hak : 06-10-2007 alle 08:45.
Tony Hak è offline   Rispondi citando il messaggio o parte di esso
Old 06-10-2007, 09:01   #13
qwerty86
Senior Member
 
L'Avatar di qwerty86
 
Iscritto dal: Jun 2007
Messaggi: 1232
Quote:
Originariamente inviato da Tony Hak Guarda i messaggi
niente... nn va ... help col dev c++ come posso vedere l'esecuzione del programma passo per passo ?
Puoi utilizzare il metodo classico , ossia utilizzare le printf per vedere cosa contengono le variabili.
__________________
Cpu: Amd 64 X2 5200+ - Mobo:M2N32SLI DELUXE - Ram: Corsair xms2 800 mhz kit 4gb - SK Video: Gaiward GTS250 - Ali : Enermax Liberty 500 Wat - Mast DVD: 2 Nec AD-5170A - Case : Thermaltake Armor+ - Dissipatore: Thermaltake V1 Notebook: Sony Vaio VGN-Fe21M-Pda: Htc Diamond |Il mio sito|Flickr| Stanco del solito forum? Vieni a parlare di fotografia su Fotoni
qwerty86 è offline   Rispondi citando il messaggio o parte di esso
Old 06-10-2007, 09:04   #14
Tony Hak
Senior Member
 
L'Avatar di Tony Hak
 
Iscritto dal: Jun 2005
Città: Napoli
Messaggi: 1661
Quote:
Originariamente inviato da qwerty86 Guarda i messaggi
Puoi utilizzare il metodo classico , ossia utilizzare le printf per vedere cosa contengono le variabili.

giusto è tutto molto "fai da te" .. secondo me cmq l'errore è nella funzione cancella.. io scambio l'elemento trovato con l'ultimo elemento dell'array e pongo l'arraysize a arraysize-1 .
__________________
Tony Hak è offline   Rispondi citando il messaggio o parte di esso
Old 06-10-2007, 10:16   #15
Tony Hak
Senior Member
 
L'Avatar di Tony Hak
 
Iscritto dal: Jun 2005
Città: Napoli
Messaggi: 1661
Codice:
#include <stdio.h>
#include <stdlib.h>
#define MAX 20
int arraysize,heapsize,tot;
int left(int i) 
{
    return 2*i+1;
}

int right(int i) 
{
    return 2*i+2;
}

int p(int i) 
{
    return (i-1)/2;
}

void swap(int A[MAX], int i, int j)
     {
              int temp = A[i];
              printf ("A[i] = %d", A[i]);
              printf ("A[j] = %d", A[j]);
              A[i] = A[j];
              A[j] = temp;
     }

void heapfy (int A[MAX], int i);
void buildheap(int A[MAX]);
int ricerca (int A[MAX],int el);
void cancella (int A[MAX],int ind);
void heapsort(int A[MAX]);

void heapfy(int A[MAX], int i)
{
     int l,r,largest;
     l=left(i);
     r=right(i);
     if (l<heapsize && A[l]>A[i])
     largest=l;
     else
     largest=i;
     if (r<heapsize && A[r] > A[largest])
     largest=r;
     if (largest != i )
     {
                 swap (A,i,largest);
                 heapfy(A,largest);
     }
}


void buildheap(int A[MAX])
{
   int i,el;
   heapsize=arraysize;
   for (i=arraysize/2;i>=0;i--)
   heapfy(A,i);
   printf("\n inserisci l'elemento da cancellare: ");
      scanf ("%d",&el);
   ricerca(A,el);

}

int ricerca (int A[MAX],int el)
{
    int i,x ;
    i=x=0;
    while  ((i<= arraysize) && (x==0))
    {
           if (el <= A[i])
           {
                  if (A[i] == el) 
                  {
                          cancella (A,i);
                          
                          x=1;
                          return arraysize-=1;
                  }
                  else
                      i+=1;
           }
           else
               x=1;
    }
}

void cancella (int A[MAX],int ind)
{
   int k=0;
   swap (A,ind,arraysize);
   for (k=0;k<arraysize;k++)
      printf("%d",A[k]);

} 
           
    
    
    

void heapsort(int A[MAX])
{
     int i;
     buildheap(A);
     for (i=arraysize-1;i>=1; i--)
     {
         swap (A,0,i);
         heapsize--;
         heapfy(A,0);
     }
}

main()
{
      int A[MAX],k;
      printf("\n quanti elementi deve contenere l'array?");
      scanf("%d",&tot);
      while (tot>MAX)
            {
                     printf("\n max 20 elementi: ");
                     scanf ("%d",&tot);
            }
      for (k=0; k<tot; k++)
      {
          printf("\n inserire il %d° elemento: ",k+1);
          scanf("%d",&A[k]);
      }
      heapsize=arraysize=tot;
      printf ("l'arrayzizze e' %d",arraysize);
      heapsort(A);
      printf ("l'arrayzizze e' %d",arraysize);
      printf("\n array ordinato:");
      for (k=0;k<arraysize;k++)
      printf("%d",A[k]);
      scanf("%d");
      system ("\n pause");
}
ho modificato ancora il codice .. ma continua a nn fungere..stavolta l'arraysize -=1 l'ho messo nella procedura di ricerca..in quanto nel VOID nn mi restituiva il valore... help vi prego..sto perdendo la testa ...

ps i vari printf sono come test
__________________
Tony Hak è offline   Rispondi citando il messaggio o parte di esso
Old 06-10-2007, 10:57   #16
rozpo
Senior Member
 
L'Avatar di rozpo
 
Iscritto dal: Feb 2006
Città: Villa di Briano (CE)
Messaggi: 408
sono il prof aniello murano
ti ho sgamato furbacchione!
__________________
Ho acquistato da: battalion75, [Riot]-kyashan, Tedio, silentmodena, dorcon, Damianoo, lantony, evl, max7_4, elpampa19, fa, Sclergio, maui_, Vastx, no_side_fx, jokervero e... dimentico sempre qualcuno.
Ho venduto a TNOTB, Ryujimihira, marcus24 e schumyFast per ora.
rozpo è offline   Rispondi citando il messaggio o parte di esso
Old 06-10-2007, 11:10   #17
Tony Hak
Senior Member
 
L'Avatar di Tony Hak
 
Iscritto dal: Jun 2005
Città: Napoli
Messaggi: 1661
Quote:
Originariamente inviato da rozpo Guarda i messaggi
sono il prof aniello murano
ti ho sgamato furbacchione!
hihi .. nn sapevo che Lei avesse 22 anni
__________________
Tony Hak è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Il cuore digitale di F1 a Biggin Hill: l’infrastruttura Lenovo dietro la produzione media Il cuore digitale di F1 a Biggin Hill: l’infrast...
DJI Osmo Mobile 8: lo stabilizzatore per smartphone con tracking multiplo e asta telescopica DJI Osmo Mobile 8: lo stabilizzatore per smartph...
Recensione Pura 80 Pro: HUAWEI torna a stupire con foto spettacolari e ricarica superveloce Recensione Pura 80 Pro: HUAWEI torna a stupire c...
Opera Neon: il browser AI agentico di nuova generazione Opera Neon: il browser AI agentico di nuova gene...
Wind Tre 'accende' il 5G Standalone in Italia: si apre una nuova era basata sui servizi Wind Tre 'accende' il 5G Standalone in Italia: s...
Le carte collezionabili dell'INPS conqui...
Football Manager 26 debutta su Steam con...
A 189,99€ con coupon: il NAS UGREEN che ...
Arm cresce ancora: ricavi oltre 1 miliar...
Xiaomi Redmi Note 14 5G ora a soli 179€:...
Spotify dovrà affrontare una nuov...
17,69€: praticamente regalato il caricat...
ECOVACS DEEBOT T80 OMNI, 600€ di sconto ...
EA fa chiarezza su controllo creativo e ...
Google Maps punta sull'AI: tante novit&a...
Qualcomm guarda oltre gli smartphone: ri...
539€, 629€ o 679€: 3 portatili HP o Acer...
Anche OnePlus attinge ai nomi scelti da ...
Apple non si arrende: altre due generazi...
Sky Mobile diventerà un vero e pr...
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: 10:17.


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