Torna indietro   Hardware Upgrade Forum > Software > Programmazione

NZXT H9 Flow RGB+, Kraken Elite 420 e F140X: abbiamo provato il tris d'assi di NZXT
NZXT H9 Flow RGB+, Kraken Elite 420 e F140X: abbiamo provato il tris d'assi di NZXT
Nelle ultime settimane abbiamo provato tre delle proposte top di gamma di NZXT nelle categorie case, dissipatori e ventole. Rispettivamente, parliamo dell'H9 Flow RGB+, Kraken Elite 420 e F140X. Si tratta, chiaramente, di prodotti di fascia alta che si rivolgono agli utenti DIY che desiderano il massimo per la propria build. Tuttavia, mentre i primi due dispositivi mantengono questa direzione, le ventole purtroppo hanno mostrato qualche tallone d'Achille di troppo
ASUS ROG Swift OLED PG34WCDN recensione: il primo QD-OLED RGB da 360 Hz
ASUS ROG Swift OLED PG34WCDN recensione: il primo QD-OLED RGB da 360 Hz
ASUS ROG Swift OLED PG34WCDN è il primo monitor gaming con pannello QD-OLED Gen 5 a layout RGB Stripe Pixel e 360 Hz su 34 pollici: lo abbiamo misurato con sonde colorimetriche e NVIDIA LDAT. Ecco tutti i dati
Recensione Nothing Phone (4a) Pro: finalmente in alluminio, ma dal design sempre unico
Recensione Nothing Phone (4a) Pro: finalmente in alluminio, ma dal design sempre unico
Nothing Phone (4a) Pro cambia pelle: l'alluminio unibody sostituisce la trasparenza integrale, portando una solidità inedita. Sotto il cofano troviamo uno Snapdragon 7 Gen 4 che spinge forte, mentre il display è quasi da top dig amma. Con un teleobiettivo 3.5x e la Glyph Matrix evoluta, è la prova di maturità di Carl Pei. C'è qualche compromesso, ma a 499EUR la sostanza hardware e la sua unicità lo rendono un buon "flagship killer" in salsa 2026
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 04-09-2015, 15:37   #1
.Zero
Junior Member
 
Iscritto dal: Sep 2015
Messaggi: 9
[ C ] Problema liste

Salve a tutti!

In questi giorni sto affrontando lo studio delle liste nel linguaggio C e un piccolo problema è affiorato durante lo svolgimento di qualche esercizio.

Sostanzialmente, il mio problema lo riscontro nel main: non riesco a inizializzare n stringhe in una lista.

Qualcuno può aiutarmi a capire come risolvere questo problema? Io proprio non riesco a venire a capo.
.Zero è offline   Rispondi citando il messaggio o parte di esso
Old 04-09-2015, 18:03   #2
.Zero
Junior Member
 
Iscritto dal: Sep 2015
Messaggi: 9
Quote:
Originariamente inviato da Antonio23 Guarda i messaggi
scusami, ma ho la palla di vetro dal meccanico.

Se magari dai qualche dettaglio del problema o fai vedere il codice magari qualcuno ti rispondera' anche...
Si, scusami! Questa è la traccia:

Si vuole una funzione che elimina tutti i nodi di una lista contenenti una data chiave. Quella di input è una lista concatenata.
La chiave contenuta in ogni nodo è una stringa, quindi il prototipo dei nodi sarà:

struct nodo {
char *chiave;
struct nodo *prec;
struct nodo *succ;
};

Questo è il prototipo della funzione:

struct nodo *DividiLista (nodo *a, char *k);

dove a è la lista da cui bisogna eliminare tutti i nodi che contengono, nel campo chiave, una stringa uguale a k.

Per quanto riguarda il codice, l'ho fatto e non dovrebbero esserci errori sintattici, ma non riuscendo a costruire il main ( per il problema sopra esposto ) non capisco se è funzionante o meno.
Se comunque potrebbe servire lo inserisco.
.Zero è offline   Rispondi citando il messaggio o parte di esso
Old 04-09-2015, 20:43   #3
.Zero
Junior Member
 
Iscritto dal: Sep 2015
Messaggi: 9
Quote:
Originariamente inviato da Antonio23 Guarda i messaggi
si, posta anche il main()...
Il main non l'ho fatto ( non riesco a impostarlo ). Per codice intendevo le funzioni che mi servono per risolvere il problema. Comunque, questo è quello che ho scritto:

#include <stdio.h>
#include <stdlib.h>
#include <string.h>

struct nodo {

char *chiave;
struct nodo *prec;
struct nodo *succ;

};
typedef struct nodo nodo;




nodo *DividiLista ( nodo *a, char *k ) {

nodo *p;
int f;
p = a;

f = strcmp ( p->chiave, k );


while ( p != NULL ) {

if (( f < 0 ) || ( f > 0 )){
p = p->succ;

}

if ( (f == 0) && (p->succ = NULL) ) {

p = p->prec;
free ( p->succ->chiave );
free ( p->succ );

}

if (( f == 0 )&& ( a = p )) {

a = a->succ;
p = p->succ;
free (p->prec->chiave);
free ( p->prec );

}

if (( f == 0 ) && ( p != a)) {


free ( p->chiave );
free ( p );
p->prec->succ = p->succ;
p->succ->prec = p->prec;
p = p->succ;

}

p = p->succ;

}

return a;

}
.Zero è offline   Rispondi citando il messaggio o parte di esso
Old 05-09-2015, 08:43   #4
.Zero
Junior Member
 
Iscritto dal: Sep 2015
Messaggi: 9
Codice:
#include <stdlib.h>
#include <string.h>
#include <stdio.h>

struct nodo 
{
    char *chiave;
    struct nodo *prec, *succ;

};
typedef struct nodo nodo;

nodo *DividiLista(nodo*, char*);
nodo *CancellaZero(nodo*);
nodo *CancellaUno(nodo*);



nodo *DividiLista( nodo *a, char *k )
{
    nodo *p;

    while ( a != NULL && strcmp(a->chiave, k) == 0 ){
        a = CancellaZero( a );
   
    }

    if ( a == NULL )
{
        return NULL;
   
   }


    p = a;

    while( p->succ != NULL )
{
        if ( strcmp(p->succ->chiave, k) == 0 ){ 
            p = CancellaUno( p );
        
        } else {
        
           p = p->succ; 
       
            }
    }

    return a;
}


nodo *CancellaZero( nodo *a )
{
    nodo *p;
    if ( a == NULL )
        return NULL;

    p  = a->succ;

    if( p != NULL)
        p->prec = NULL;

    free(a->chiave);
    free(a);
    return p;
}


nodo *CancellaUno( nodo *a)
{ 
    nodo *p;
   
     if( a->succ == NULL )
        return a;
    
      p = a->succ;
      a->succ = p->succ;
    
       if(p->succ != NULL)
        p->succ->prec = a;
      free(p->chiave);
      free(p);
      return a;
}

Ultima modifica di .Zero : 05-09-2015 alle 10:25.
.Zero è offline   Rispondi citando il messaggio o parte di esso
Old 05-09-2015, 16:34   #5
.Zero
Junior Member
 
Iscritto dal: Sep 2015
Messaggi: 9
Quote:
Originariamente inviato da Antonio23 Guarda i messaggi
codice tra tag "code" e reindentazione... la prima volta l'ho fatto io, ora fallo tu cosi' e' piu' leggibile
Sistemato, e spero che ora sia più leggibile.
.Zero è offline   Rispondi citando il messaggio o parte di esso
Old 06-09-2015, 20:22   #6
.Zero
Junior Member
 
Iscritto dal: Sep 2015
Messaggi: 9
Mmh... ho capito.
E ora come faccio a costruire la funzione main per far partire il programma?
.Zero è offline   Rispondi citando il messaggio o parte di esso
Old 07-09-2015, 15:40   #7
.Zero
Junior Member
 
Iscritto dal: Sep 2015
Messaggi: 9
Tenendo presente quello che hai scritto ho progettato il main nel modo seguente:

Codice:
int main () {

char *s[5] = {"cane", "gatto", "camaleonte", "leone", "scimmia"};
char *c = {"gatto"};
char *l = {"leone"};


nodo *a = NULL;
int i;

for ( i = 0; i<=5; i++ ) {

a = InserisciLista ( a, s[i], 0 );

       }

a = DividiLista( a, c, l );

MostraLista(a);

  }
Dove "InserisciLista" è definita come segue:
Codice:
nodo *InserisciLista( nodo *a, char *chiave, int i ){
    nodo *p, *q;
    if( i == 0){
        p = malloc(sizeof(nodo));
        p->chiave = chiave;
        p->prec = NULL;
        p->succ = a;
        if( a != NULL)
            a->prec = p;
        a = p;
    } else {
        p = malloc(sizeof(nodo));
        p->chiave = chiave;
        p->prec = a;
        p->prec->succ = p;
         a = p;
        }
      return a;
          }
"DividiLista" è la funzione che ho già presentato in qualche messaggio precedente. Infine, "MostraLista" non fa altro che mostrare a video il risultato. Purtroppo quando vado a compilare il tutto mi dà errore.
.Zero è offline   Rispondi citando il messaggio o parte di esso
Old 12-09-2015, 07:29   #8
.Zero
Junior Member
 
Iscritto dal: Sep 2015
Messaggi: 9
Quote:
Originariamente inviato da Antonio23 Guarda i messaggi
inserisci lista mi sembra inutilmente complicata, se vuoi semplicemente inserire in coda

Codice:
   void insertLista(list *p, char *string)
   {
      // this assumes that p exists, i.e. not NULL
      if (!p)
         return;

      while (p->next)
      {
         p = p->next;       
      }

      p->next = (list *) malloc(sizeof(list));
      strcpy( p->next->key, string );
      p->next->prev = p;
      p->next->next = NULL;

   }
non capisco quell'intero i a che serva nella tua funzione...
Eccomi!
Perdona l'attesa ma sono stato senza internet in questi giorni.

"i" mi permette di far partire la funzione, fondamentalmente, perché nel main lo imposto come 0 ( zero ) e, quindi, mi fa partire la funzione. Un controllo inutile, pensi?
.Zero è offline   Rispondi citando il messaggio o parte di esso
Old 14-09-2015, 19:10   #9
.Zero
Junior Member
 
Iscritto dal: Sep 2015
Messaggi: 9
Quote:
Originariamente inviato da Antonio23 Guarda i messaggi
si, ora ho capito. secondo me e' inutilmente complicato.
Si, è solo per permettere alla funzione di partire.
Ho risolto il problema, comunque. Ho utilizzato la funzione "InserisciZero" e ho inserito manualmente le varie parole, senza utilizzare altre funzioni:

Codice:
 
nodo *InserisciZero(nodo *a, char *k){
    nodo *p;
    p = malloc(sizeof(nodo));
    p->chiave = k;
    if( a == NULL){
        p->succ = NULL;
        p->prec = NULL;
        return p;
    }
    p->succ = a;
    p->prec = NULL;
    a->prec = p;
    return p;
}
E nel main ho semplicemente utilizzato la suddetta funzione più volte, così da riempire la lista a mio piacimento:

Codice:
main(){
nodo *a= NULL;

a = InserisciZero(a, "bue");
a = InserisciZero(a, "capra");
a = InserisciZero(a, "serpente");
a = InserisciZero(a, "maiale");
a = InserisciZero(a, "topo");

char *k = "capra";
char *k1 = "maiale";

printf("Lista originale:\n");
MostraLista(a);

a = EstraiSegmento(a, k, k1);

printf("Lista modificata:\n");
MostraLista(a);
}
Grazie per i chiarimenti, gli aiuti e il tempo messo a disposizione.
.Zero è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


NZXT H9 Flow RGB+, Kraken Elite 420 e F140X: abbiamo provato il tris d'assi di NZXT NZXT H9 Flow RGB+, Kraken Elite 420 e F140X: abb...
ASUS ROG Swift OLED PG34WCDN recensione: il primo QD-OLED RGB da 360 Hz ASUS ROG Swift OLED PG34WCDN recensione: il prim...
Recensione Nothing Phone (4a) Pro: finalmente in alluminio, ma dal design sempre unico Recensione Nothing Phone (4a) Pro: finalmente in...
WoW: Midnight, Blizzard mette il primo, storico mattone per l'housing e molto altro WoW: Midnight, Blizzard mette il primo, storico ...
Ecovacs Goat O1200 LiDAR Pro: la prova del robot tagliaerba con tagliabordi integrato Ecovacs Goat O1200 LiDAR Pro: la prova del robot...
Anthropic ha un'AI che trova falle in Wi...
I 10 migliori sconti Amazon del weekend:...
Con un coupon scendono ancora: le super ...
Minimo storico per Samsung Galaxy S26 Ul...
Si è conclusa la missione lunare ...
EK Waterblock si arrende agli aumenti, i...
Geekbench si aggiorna: tutti i test con ...
Per la prima volta un computer quantisti...
Telecamere Reolink 4K su Amazon: Wi-Fi 6...
Anthropic vuole farsi i chip da sola? Co...
Il fondatore di Framework: il personal c...
JBL Live Flex 3 a 129€ su Amazon: ANC ad...
Come un uomo ha costruito un'azienda da ...
Multe fino a 400 euro anche se hai pagat...
Tapo lancia una valanga di offerte su Am...
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: 17:43.


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