Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Plaud NotePin S, il registratore IA si fa indossabile (ma è facile da perdere)
Plaud NotePin S, il registratore IA si fa indossabile (ma è facile da perdere)
Quattro modi di indossarlo, stessa app del Plaud Note Pro e integrazione con il desktop. Il registratore IA da indossare di Plaud eccelle in mobilità, ma resta vincolato all'abbonamento ed è facile da perdere
Redmi Watch 6 in prova: lo smartwatch con ampio display da 2000 nit a meno di 100 euro
Redmi Watch 6 in prova: lo smartwatch con ampio display da 2000 nit a meno di 100 euro
Xiaomi ha portato Redmi Watch 6 anche sul mercato italiano, puntando su un display AMOLED da 2,07 pollici con picco di luminosità a 2000 nit, frame in alluminio da 9,9mm e un'autonomia dichiarata di 12 giorni. Lo smartwatch gira su HyperOS 3 e integra GPS, Bluetooth 5.4 e oltre 150 sport mode. Il tutto a meno di 100 euro
Mad Catz M.M.O. 7+: lo stesso DNA del R.A.T. 8+ ADV, ma con molti più pulsanti
Mad Catz M.M.O. 7+: lo stesso DNA del R.A.T. 8+ ADV, ma con molti più pulsanti
Con 22 tasti, il pulsante 5D, lo Shift Mode e il sensore PixArt 3395 da 26.000 DPI, il nuovo mouse wireless di Mad Catz si rivolge in modo preciso ai giocatori di MMO e RPG. Ma chi conosce già il R.A.T. 8+ ADV si accorgerà subito di quanto i due prodotti condividano, e di dove invece divergono
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 19-05-2005, 16:16   #1
D4rkAng3l
Bannato
 
Iscritto dal: Mar 2004
Città: Roma
Messaggi: 2688
[C] problema soluzione esercizio

Ciao,
stavo vedendo gli esercizzi di esame di programmazione 1 con le relative soluzioni ma a mio modesto parere questa soluzione mi sembra sbagliata...

L'esercizio è il seguente:

"Scrivere una funzione che preso in input il puntatore al primo elemento di una lista di stringhe, elimini i duplicati e ritorni il puntatore alla lista così ripulita.

Gli elementi della lista hanno il seguente tipo:

typedef struct SList{
char str[30];
struct SList *next;
};

Il prototipo della funzione è SList *Ripulisci(SList *)

Il codice della soluzione è questa ma mi puzza:

Codice:
/* Riceve in ingresso il puntatore al primo nodo e restituisce il puntatore
    alla lista ripulita */
SList *Ripulisci(SList *list){
    if(list != NULL && list->next !! NULL){
        SList *e = list;    // Imposta il puntatore e al primo nodo
     
        do{
            if(!strcmp(e-str, e->next-str)){  // Se le stringhe sono uguali
                 SList *p = e->next;
                 e->next = p->next;
                 free(p);
            }
            else
               e = e->next;
         }while(e->next != NULL);
       }
       return list;    // Ritorna il puntatore all'inizio della lista ripulita
}
Le cose che mi sembrano strane sono 2:

1) Si dichiara ile variabili puntaore *e e *p in mezzo al codice....ma non andrebbero dichiarate all'inizio della funzione o è solo una cosa di stile?

2) la funzione compara con la strcmp il valore contenuto nel campo str puntato da e con il valore del campo str puntato da str->next.

Se alla prima esecuzione del ciclo non trova due stringhe uguali il valore di e viene fatto passare al nodo successivo con e = e->next e il ciclo ricomincia...
ma così non controlla solo nodi adiacenti?!?!

Cioè io credo che per ogni nodo dovrebbe scorrere tutti i nodi, se trova un nodo contenente la stessa stringa lo elimina e poi continua a scorrere la lista fino alla fine per vedere se c'è un altro doppione e poi rinizia il ciclo dal secondo nodo e fà la stessa cosa....

Spero di essere stato chiaro
E' sbagliata questa soluzione (quella del codice)?

Grazie
Andrea
D4rkAng3l è offline   Rispondi citando il messaggio o parte di esso
Old 19-05-2005, 17:20   #2
VICIUS
Senior Member
 
L'Avatar di VICIUS
 
Iscritto dal: Oct 2001
Messaggi: 11471
Quote:
Originariamente inviato da D4rkAng3l
Ciao,
1) Si dichiara ile variabili puntaore *e e *p in mezzo al codice....ma non andrebbero dichiarate all'inizio della funzione o è solo una cosa di stile?
Nello standard ansi è obbligatorio dichiarare tutte le varibili prima del codice. Se pero usi C99 o c++ puoi tranquillamente mischiarli.

Quote:
Originariamente inviato da D4rkAng3l
2) la funzione compara con la strcmp il valore contenuto nel campo str puntato da e con il valore del campo str puntato da str->next.
Probabilmente il professore ha assunto, o meglio ha deciso che la lista di stringhe era ordianta.

ciao
VICIUS è offline   Rispondi citando il messaggio o parte di esso
Old 19-05-2005, 17:49   #3
D4rkAng3l
Bannato
 
Iscritto dal: Mar 2004
Città: Roma
Messaggi: 2688
Quote:
Originariamente inviato da VICIUS
Nello standard ansi è obbligatorio dichiarare tutte le varibili prima del codice. Se pero usi C99 o c++ puoi tranquillamente mischiarli.


Probabilmente il professore ha assunto, o meglio ha deciso che la lista di stringhe era ordianta.

ciao

mmmm si perchè se è ordinata così funzionerebbe, però nel testo non c'è scritto ed è il secondo esercizio che trovo logicamente errato...l'altro era su un vettore di strutture...quindi non ci sono cavoli di interpretazione come questo...la cosa inizia a seccarmi....

+ più recente l'ansi o il c99? quale dei due è più usato?
D4rkAng3l è offline   Rispondi citando il messaggio o parte di esso
Old 19-05-2005, 18:06   #4
sirus
Senior Member
 
Iscritto dal: Mar 2004
Messaggi: 16053
Quote:
Originariamente inviato da D4rkAng3l
mmmm si perchè se è ordinata così funzionerebbe, però nel testo non c'è scritto ed è il secondo esercizio che trovo logicamente errato...l'altro era su un vettore di strutture...quindi non ci sono cavoli di interpretazione come questo...la cosa inizia a seccarmi....

+ più recente l'ansi o il c99? quale dei due è più usato?
è più recente il C99 e attualmente si usa il C99 come fosse ANSI o quasi anche se non si dovrebbe

comunque (non so era tutto specificato nel testo) ma il programma funziona
sirus è offline   Rispondi citando il messaggio o parte di esso
Old 19-05-2005, 18:41   #5
71104
Bannato
 
L'Avatar di 71104
 
Iscritto dal: Feb 2005
Città: Roma
Messaggi: 7029
un piccolo OT per DarkAngel: vedo che migliori a vista d'occhio: l'altro giorno ti incasinavi con un programma che prende i dati in input e li inserisce in una lista e adesso guarda come ti destreggi tra gli elementi duplicati
dai scherzi a parte, continua così e fagli vedere di che pasta sei fatto!!
PS: a voler essere veramente pignoli, potremmo dire che quella soluzione un problema ce l'ha, e per l'esattezza si tratta di un leak piuttosto grave; vediamo se lo trovi da te
71104 è offline   Rispondi citando il messaggio o parte di esso
Old 20-05-2005, 09:50   #6
D4rkAng3l
Bannato
 
Iscritto dal: Mar 2004
Città: Roma
Messaggi: 2688
Quote:
Originariamente inviato da 71104
un piccolo OT per DarkAngel: vedo che migliori a vista d'occhio: l'altro giorno ti incasinavi con un programma che prende i dati in input e li inserisce in una lista e adesso guarda come ti destreggi tra gli elementi duplicati
dai scherzi a parte, continua così e fagli vedere di che pasta sei fatto!!
PS: a voler essere veramente pignoli, potremmo dire che quella soluzione un problema ce l'ha, e per l'esattezza si tratta di un leak piuttosto grave; vediamo se lo trovi da te
mmm ora lo cerco...ma mi stai prendendo in giro cmq? stò già abbastanza depresso perchè sò che questo esame non lo passerò Scusate se in questyo periodo rompo particolarmente le balle sul forum ma stò incasinatissimo devo darlo questo esame...assolutamente...è vitale
D4rkAng3l è offline   Rispondi citando il messaggio o parte di esso
Old 20-05-2005, 11:30   #7
71104
Bannato
 
L'Avatar di 71104
 
Iscritto dal: Feb 2005
Città: Roma
Messaggi: 7029
Quote:
Originariamente inviato da D4rkAng3l
mmm ora lo cerco...ma mi stai prendendo in giro cmq?
assolutamente no! mi sa che nel mess precedente c'era qualche big grin di troppo
71104 è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Plaud NotePin S, il registratore IA si fa indossabile (ma è facile da perdere) Plaud NotePin S, il registratore IA si fa indoss...
Redmi Watch 6 in prova: lo smartwatch con ampio display da 2000 nit a meno di 100 euro Redmi Watch 6 in prova: lo smartwatch con ampio ...
Mad Catz M.M.O. 7+: lo stesso DNA del R.A.T. 8+ ADV, ma con molti più pulsanti Mad Catz M.M.O. 7+: lo stesso DNA del R.A.T. 8+ ...
Radeon RX 9070 GRE, AMD la porta in tutto il mondo | Recensione Gigabyte Gaming OC Radeon RX 9070 GRE, AMD la porta in tutto il mon...
Reolink OMVI 3i WiFi: videosorveglianza più intelligente e facile da usare Reolink OMVI 3i WiFi: videosorveglianza pi&ugrav...
Virtua Fighter è tornato e non &e...
Il ritorno di Fumito Ueda, autore di Sha...
Cooler Master svela GPU Shield, la nuova...
Samsung Galaxy S27 Pro: sarà lui ...
Così Google ha ottimizzato Chrome...
Xiaomi non cambia idea: il display poste...
LG presenta in Italia le gamme TV Micro ...
Sette anni dopo l'annuncio, The Wolf Amo...
'Non avrete aumenti': la decisione shock...
TIM lancia il Pass Mondiali DAZN: 104 pa...
Tesla Roadster, promessa o miraggio? La ...
Mark Hamilton, la tavola periodica del m...
Hanger 13 annuncia Uomo d'Onore: espansi...
La battaglia delle HBM4 entra nel vivo: ...
Dopo 12 anni torna Alien: Isolation. Ecc...
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:27.


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