Torna indietro   Hardware Upgrade Forum > Software > Programmazione

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
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, ecco cosa può (e non può) fare
A New York HP ha messo al centro della scena HP IQ, la piattaforma di IA locale da 20 miliardi di parametri. L’abbiamo vista in funzione: è uno strumento che funziona, pensato per un target specifico, con vantaggi reali e limiti altrettanto evidenti
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 05-10-2007, 17: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, 20: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, 20: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 20:55.
Tony Hak è offline   Rispondi citando il messaggio o parte di esso
Old 05-10-2007, 20: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, 20: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 21:03.
Tony Hak è offline   Rispondi citando il messaggio o parte di esso
Old 05-10-2007, 21: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, 21: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, 22: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, 22: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 05-10-2007, 23: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, 07: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, 07: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 07:45.
Tony Hak è offline   Rispondi citando il messaggio o parte di esso
Old 06-10-2007, 08: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, 08: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, 09: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, 09: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, 10: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


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...
Wi-Fi 7 con il design di una vetta innevata: ecco il nuovo sistema mesh di Huawei Wi-Fi 7 con il design di una vetta innevata: ecc...
NVIDIA App si aggiorna: arriva DLSS 4.5 ...
Claude Code: il codice sorgente esposto ...
Recensione POCO X8 Pro: è lui lo ...
Il primo dissipatore a liquido di Noctua...
Opera Neon abilita il protocollo MCP: l'...
Dyson Clean+Wash Hygiene: lava e pulisce...
NVIDIA investe 2 miliardi in Marvell: pa...
Le GPU come garanzia bancaria: CoreWeave...
KeeneticOS si aggiorna alla versione 5: ...
Regno Unito avvia indagine su Microsoft:...
Disney vuole comprare Epic Games e Fortn...
ASUS ROG Crosshair X870E Glacial: il nuo...
Samsung Galaxy Watch 9 si avvicina al la...
GTA 6: i costi di sviluppo sono impressi...
SSD Kioxia EXCERIA PRO G2 4TB, prestazio...
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: 00:21.


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