Torna indietro   Hardware Upgrade Forum > Software > Programmazione

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.
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.
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 16-07-2007, 19:35   #1
Xfree
Senior Member
 
L'Avatar di Xfree
 
Iscritto dal: Aug 2001
Messaggi: 9538
[C] Ricerca binaria in un ABR

Ciao a tutti.
Ho fatto un piccolo esercizio che carica da file delle informazioni riguardanti i generi dei libri in un ABR e poi ricerca il genere nell'albero stesso,
solo che quest'ultima non c'è verso di farla funzionare.
Mi da sempre "Non trovato", quindi come se il puntatore fosse sempre NULL,
ma non sono riuscito a capire perché.

Codice del programma
Codice:
/* 
   Creazione di un albero binario con lettura informazioni da file e visita in ordine anticipato
   e ricerca binaria.   L'etichetta dei nodi è una stringa.         
*/

#include <stdio.h>
#include <malloc.h>
#define MAX 50

struct nodo {
   char inf[MAX];
   struct nodo *sx;
   struct nodo *dx;
};

struct tlibro{
   char autori[MAX];
   char titolo[MAX];
   char tipologia[MAX];
};

struct nodo *albBin(void);
struct nodo *creaNodo(struct nodo *, char val[]);
void anticipato(struct nodo *);
void ricBin(char val[],struct nodo *);

main()
{
   char cerca[MAX];
   struct nodo *radice;    /* puntatore alla radice dell'albero  */
   radice = albBin();      /* invoca la funzione per la creazione 
                           dell'albero binario                */
   printf("\nVISITA IN ORDINE ANTICIPATO\n");
   anticipato(radice);
   printf("\nRICERCA BINARIA\n");
   printf("Inserisci la stringa da cercare: ");
   scanf("%s",&cerca);
   ricBin(cerca,radice);
   system("pause");
}


/* Crea l'albero binario. Per ogni etichetta immessa
   dall'utente, invoca la funzione creaNodo.
   Ritorna al chiamante la radice dell'albero        */

struct nodo *albBin(void)
{
   struct nodo *p = NULL;
   struct tlibro libro;
   FILE *fp;
   
   fp=fopen("libri.txt","r");
   if(fp==NULL)
      printf("Si e' verificato un'errore nell'apertura del file\n");
   else{
      while(!feof(fp)){
         fgets(libro.autori,MAX,fp);
         fgets(libro.titolo,MAX,fp);
         fgets(libro.tipologia,MAX,fp);
         p=creaNodo(p,libro.tipologia);
         //printf("%s",libro.autori);
         //printf("%s",libro.titolo);
         //printf("%s",libro.tipologia);
      }
      fclose(fp);
   }
   return(p);                       /* ritorna la radice */
}


/* Visita ricorsivamente l'albero alla ricerca del punto di 
   inserimento. Quando trova la posizione, crea un nodo, vi  
   inserisce l'etichetta e ritorna il puntatore a tale nodo.
   Parametri in ingresso:
      p      e' il puntatore alla radice
      val    e' l'etichetta da inserire nel nodo             */


struct nodo *creaNodo(struct nodo *p, char val[])
{
   if(p==NULL) {       /* il punto di inserimento e' stato reperito */
   /* Creazione del nodo */
      p=(struct nodo *) malloc(sizeof(struct nodo));
      strcpy(p->inf,val);            /* inserimento di val in elemento */
      p->sx = NULL;        /* marca di albero sinistro vuoto */
      p->dx = NULL;        /* marca di albero destro vuoto   */
   }
   else{              /* ricerca del punto di inserimento */
      if(strcmp(val,p->inf)>0){
         /* Visita il sottoalbero destro */
         p->dx = creaNodo(p->dx, val);
      }
      else{
         /* Visita il sottoalbero sinistro */
         p->sx = creaNodo(p->sx, val);
      }
   }
   return(p);                  /* ritorna il puntatore alla radice */
}


/* Visita l'albero binario in ordine anticipato */

void anticipato(struct nodo *p)
{
   if(p!=NULL) {
      
      printf("%s",p->inf);    /* visita la radice */
      anticipato(p->sx);     /* visita il sottoalbero sinistro */
      anticipato(p->dx);     /* visita il sottoalbero destro   */
   }
}

void ricBin(char val[],struct nodo *p)
{
   if(p==NULL)
      printf("Non trovato");
   else if(strcmp(val,p->inf)==0)
      printf("Trovato");
   else if(strcmp(val,p->inf)<0) 
      ricBin(val,p->sx);
   else 
      ricBin(val,p->dx);
}
File libri.txt
Quote:
DANTE
LA DIVINA COMMEDIA
COMMEDIA
DESCARTES
DISCORSO SUL METODO
SAGGISTICA
UMBERTO ECO
IL NOME DELLA ROSA
LETTERATURA
JULES VERNE
20000 LEGHE SOTTO I MARI
FANTASCIENZA
NICK HORNBY
ALTA FEDELTA
ROMANZO
Xfree è offline   Rispondi citando il messaggio o parte di esso
Old 17-07-2007, 13:21   #2
labrosan
Junior Member
 
Iscritto dal: Apr 2007
Messaggi: 27
Devi stare attento a due cose:

1)"CASA" è diverso da "casa".
Il tuo file libri.txt è scritto in maiuscolo, mentre un operatore probabilmente inserirà un nome minuscolo. Per fare il confronto usa la stricmp()

2)La fgets include anche il carattere '\n'.
"casa\n" è diverso da "casa", quindi devi tenerne conto
labrosan è offline   Rispondi citando il messaggio o parte di esso
Old 17-07-2007, 15:50   #3
Xfree
Senior Member
 
L'Avatar di Xfree
 
Iscritto dal: Aug 2001
Messaggi: 9538
Ok, grazie per le osservazioni.
Per il primo punto lo sapevo e l'ho deliberatamente lasciato così perché facendo le prove io già facevo la ricerca in maiuscolo; quella funzione comunque non la conoscevo per cui grazie.
Per il secondo punto quindi i nodi dell'albero binario contengono il '\n' mentre la stringa che immetto io non lo contiene, il problema nasce quindi da qui?
Xfree è offline   Rispondi citando il messaggio o parte di esso
Old 17-07-2007, 18:00   #4
labrosan
Junior Member
 
Iscritto dal: Apr 2007
Messaggi: 27
Ho provato al volo con questa modifica e funziona.

Codice:
while(!feof(fp)){
         fgets(libro.autori,MAX,fp);
             if (libro.autori[strlen(libro.autori)-1]=='\n')
                  libro.autori[strlen(libro.autori)-1]='\0';
         fgets(libro.titolo,MAX,fp);
              if (libro.titolo[strlen(libro.titolo)-1]=='\n')
                    libro.titolo[strlen(libro.titolo)-1]='\0';
         fgets(libro.tipologia,MAX,fp);
            if (libro.tipologia[strlen(libro.tipologia)-1]=='\n')
                  libro.tipologia[strlen(libro.tipologia)-1]='\0';
Ancora una osservazione: quando fai scanf("%s",&cerca), l'operatore & non devi metterlo poichè la stringa è gia passata per riferimento

Ciao Ciao
labrosan è offline   Rispondi citando il messaggio o parte di esso
Old 17-07-2007, 19:02   #5
Xfree
Senior Member
 
L'Avatar di Xfree
 
Iscritto dal: Aug 2001
Messaggi: 9538
Fatto come dici tu e funziona.
Quindi il problema non era dell'algoritmo della ricerca binaria ma nel carattere di fine stringa che non essendo uguale tra l'informazione contenuta nell'etichetta dell'albero e quella acquisita da tastiera dava il risultato di non trovare mai nulla.
Approfitto della tua presenza per chiederti un'altra cosa:
se io volessi modificare il programma facendo in modo tale che l'albero binario sia ordinato per tipologia (e qui già è fatto così) ma con il vincolo che ogni nodo dell'albero binario deve contenere le informazioni dei libri della stessa tipologia organizzati nel seguente modo:
tipologia
lista dei libri della stessa tipologia

e per ogni libro sono memorizzati
autori
titolo del libro.

Per lista io ho capito che si intende lista nel senso di struttura dati dinamica, quindi all'interno del nodo dell'albero ci dovrebbe essere puntatore ad una lista
del tipo
Codice:
struct lista{
 char autori[MAX];
 char titolo[MAX];
 struct lista *next;
}
e quindi poi gestire il tutto con le operazioni proprie delle liste, giusto?

Ultima modifica di Xfree : 17-07-2007 alle 19:52.
Xfree è offline   Rispondi citando il messaggio o parte di esso
Old 17-07-2007, 19:29   #6
labrosan
Junior Member
 
Iscritto dal: Apr 2007
Messaggi: 27
Ok
labrosan è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


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 ...
Redmi Note 15 Pro+ 5G: autonomia monstre e display luminoso, ma il prezzo è alto Redmi Note 15 Pro+ 5G: autonomia monstre e displ...
Questo robot aspirapolvere da 13.000 Pa ...
Supercomputer AI, segreti rubati e Cina:...
Huang smentisce le tensioni con OpenAI e...
Epic supporta la causa legale contro Val...
Uno dei più importanti network il...
Coupon Amazon nascosti, ecco quelli nuov...
Videocitofoni Ring, 6 articoli in super ...
A 369€ non si batte: ECOVACS DEEBOT T50 ...
Xiaomi 17: ecco il prezzo europeo del to...
Google fa tremare l'industria dei videog...
Gli sviluppatori 'abbandonano' Xbox: il ...
Galaxy S27 Ultra, è già te...
PlayStation Portal con display OLED: Son...
POCO X8 Pro e Pro Max sono quasi pronti:...
OpenAI ha bisogno di nuovi fondi: NVIDIA...
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: 09:09.


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