Torna indietro   Hardware Upgrade Forum > Software > Programmazione

FRITZ!Repeater 1700 estende la rete super-veloce Wi-Fi 7
FRITZ!Repeater 1700 estende la rete super-veloce Wi-Fi 7
FRITZ!Repeater 1700 porta il Wi-Fi 7 dual-band nelle case connesse. Mette a disposizione fino a 2.880 Mbit/s su 5 GHz e 688 Mbit/s su 2,4 GHz, integrazione Mesh immediata via WPS con FRITZ!Box e funzioni smart come MLO per bassa latenza. Compatto, plug-and-play e pronto per il futuro, è la soluzione ideale per chi vuole coprire ogni angolo senza cavi o complicazioni
Fondazione Chips-IT, l'Italia alla riscossa nei chip. Il piano e la partnership EssilorLuxottica
Fondazione Chips-IT, l'Italia alla riscossa nei chip. Il piano e la partnership EssilorLuxottica
La Fondazione Chips-IT ha presentato a Pavia il piano strategico 2026-2028 per rafforzare l'ecosistema italiano dei semiconduttori. Con un focus su ricerca, design, talenti e infrastrutture, la Fondazione punta a consolidare il ruolo dell'Italia nel Chips Act europeo, sostenendo innovazione, collaborazione industriale e sovranità tecnologica.
Nutanix: innovazione, semplicità e IA al centro della strategia hybrid multicloud
Nutanix: innovazione, semplicità e IA al centro della strategia hybrid multicloud
Al Museo Alfa Romeo di Arese, Nutanix ha riunito clienti, partner ed esperti per .Next On Tour Italia e per mostrare come l’infrastruttura hybrid multicloud possa diventare il fondamento dell’innovazione, con una piattaforma capace di unificare applicazioni tradizionali, moderne architetture cloud-native e nuovi scenari basati sull’intelligenza artificiale
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 07-08-2007, 09:34   #1
xbubbax
Senior Member
 
Iscritto dal: Apr 2007
Messaggi: 381
[C] Inizializzare lista

Allora, ho studiato le liste, ho capito come si fanno le operazioni su di essa ma non so come si dichiara, nel senso come si inseriscono i valori nei vari nodi.

ho provato a scrivere questo, ad esempio se voglio inizializzare i primi 3 nodi con gli elementi 27 7 87 come si fa? mi serve la procedura piu semplice, giusto per capire il meccanismo
Codice HTML:
#include <stdio.h>
struct nodo{
       int data;
       struct nodo* ptr;}:
int main(){
           
           typedef struct nodo NODO;
           typedef struct nodo* NODOptr;
xbubbax è offline   Rispondi citando il messaggio o parte di esso
Old 07-08-2007, 09:45   #2
xbubbax
Senior Member
 
Iscritto dal: Apr 2007
Messaggi: 381
ad esempio ho scritto questo programmino per stampare una lista, ma mi manca il pezzo dove inserisco gli elementi della lista, ora provo a scrivero io ma non penso di riuscirci

Codice HTML:
#include <stdio.h>
struct nodo{
       int data;
       struct nodo* ptr;}:
int main(){
           
           typedef struct nodo NODO;
           typedef struct nodo* NODOptr;
           
           
           


void stampalista(NODOptr L1){
     
     if(L1!=NULL){
                  printf("->%d", L1->elem);
                  stampalista(L1->next);}
                  else printf("->NULL");}
xbubbax è offline   Rispondi citando il messaggio o parte di esso
Old 07-08-2007, 09:55   #3
andbin
Senior Member
 
L'Avatar di andbin
 
Iscritto dal: Nov 2005
Città: TO
Messaggi: 5206
Codice:
#include <stdio.h>
#include <stdlib.h>

typedef struct nodo
{
    int data;
    struct nodo *next;
} NODO, *PNODO, **PPNODO;

int List_Append (PPNODO pproot, int data)
{
    PNODO pnodo;

    if (pproot == NULL)
        return 0;

    if ((pnodo = (PNODO) malloc (sizeof (NODO))) == NULL)
        return 0;

    pnodo->data = data;
    pnodo->next = NULL;

    while (*pproot != NULL)
        pproot = &(*pproot)->next;
    
    *pproot = pnodo;
    return 1;
}

int main (void)
{
    PNODO proot = NULL;

    List_Append (&proot, 27);
    List_Append (&proot, 7);
    List_Append (&proot, 87);

    return 0;
}
Nota: per brevità nel main non ho testato il valore di ritorno di List_Append.
__________________
Andrea, SCJP 5 (91%) - SCWCD 5 (94%)
andbin è offline   Rispondi citando il messaggio o parte di esso
Old 07-08-2007, 10:04   #4
xbubbax
Senior Member
 
Iscritto dal: Apr 2007
Messaggi: 381
mi stai facendo impazzire andbin

non c'è un modo piu semplice? magari lasciando il mio programma così com'è e aggiungendo solo il necessario per le dichiarazioni?
xbubbax è offline   Rispondi citando il messaggio o parte di esso
Old 07-08-2007, 10:11   #5
andbin
Senior Member
 
L'Avatar di andbin
 
Iscritto dal: Nov 2005
Città: TO
Messaggi: 5206
Quote:
Originariamente inviato da xbubbax Guarda i messaggi
non c'è un modo piu semplice? magari lasciando il mio programma così com'è e aggiungendo solo il necessario per le dichiarazioni?
Più semplice??

Più semplice di così si muore!! C'è da fare sostanzialmente 4 cose: allocare la nuova struttura, inizializzarla, cercare il fondo della lista e accodare il nodo.

Nel mio codice ho solo messo dei nomi di mio gradimento ma il succo è quello. Anzi il mio codice è sicuramente pulito e lineare. Cerca di capire cosa fa List_Append e avrai capito come si aggiunge un nodo.
__________________
Andrea, SCJP 5 (91%) - SCWCD 5 (94%)
andbin è offline   Rispondi citando il messaggio o parte di esso
Old 07-08-2007, 10:13   #6
xbubbax
Senior Member
 
Iscritto dal: Apr 2007
Messaggi: 381
si infatti devo leggerla bene, ora intanto sto imparando a fare le funzioni sulle liste, tipo ricerca di un elemento, somma degli elementi ecc... e poi cerco di capire come si inizializzano
xbubbax è offline   Rispondi citando il messaggio o parte di esso
Old 09-08-2007, 13:24   #7
Baronerosso9
Junior Member
 
Iscritto dal: Aug 2007
Messaggi: 22
Allora...la lista che vuoi creare te mi sembra di capire che sia una lista in forma collegata con puntatori.
Allora devi, prima dichiarare nel main una variabile di tipo puntatore a lista(è il buffer dove terrai memorizzato il primo valore della lista). Poi inizializzi la lista ( cioè il puntatore lo imposti uguale a NULL). (per inizializzare una variabile da un'altra funzione devi passare il puntatore a tale variabile, quindi in questo caso devi passare un doppio puntatore). dopo aver inizializzato...inserisci come sta scritto nel mio codice:

struct list
{
float value;
struct list * nextptr;
};

void init(struct list ** ptrptr) //inizializzazione
{
*ptrptr=NULL;
}

void preinsert(struct list ** ptrptr, float value) //inserimento in testa
{
struct list * tmpptr;
tmpptr=*ptrptr;
*ptrptr=(struct list *)malloc(sizeof(struct list));
(*ptrptr)->nextptr=tmpptr;
(*ptrptr)->value=value;
}

void sufinsert(struct list **ptrptr, float value) //inserimento in coda
{
while (*ptrptr!=NULL)
ptrptr=&((*ptrptr)->nextptr);
preinsert(ptrptr,value);
}


int main(int argc, char *argv[])
{
struct list * ptr;
float valore;
init(&ptr);
.
.
.
preinsert(&ptr,valore);
.
.
.
sufinsert(&ptr,valore);
return 0;
}

Spero sia tutto chiaro...cerca sempre di dividere un problema insormontabile in tanti problemini facili (funzioni).
A presto
Baronerosso9 è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


FRITZ!Repeater 1700 estende la rete super-veloce Wi-Fi 7 FRITZ!Repeater 1700 estende la rete super-veloce...
Fondazione Chips-IT, l'Italia alla riscossa nei chip. Il piano e la partnership EssilorLuxottica Fondazione Chips-IT, l'Italia alla riscossa nei ...
Nutanix: innovazione, semplicità e IA al centro della strategia hybrid multicloud Nutanix: innovazione, semplicità e IA al ...
Lenovo LOQ 15i Gen 10 (15IRX10) alla prova: il notebook gaming 'budget' che non ti aspetti Lenovo LOQ 15i Gen 10 (15IRX10) alla prova: il n...
Due mesi di Battlefield 6: dalla campagna al battle royale, è l'FPS che stavamo aspettando Due mesi di Battlefield 6: dalla campagna al bat...
Il prezzo della Steam Machine potrebbe e...
Ratti con una postazione da gaming enthu...
Samsung Galaxy S26: a causa dell'IA potr...
Xiaomi esagera: in arrivo uno smartphone...
La crisi delle memorie colpirà an...
I giovani russi non ci stanno: ondata di...
Dal sogno della guida autonoma al fallim...
Antitrust UE: maxi multa da 72 milioni a...
Il futuro dei chip è verticale: R...
Accenture e Anthropic insieme per aiutar...
Fino a 360 GB su un vetro grande come un...
tado° porta il bilanciamento idrauli...
Metallo liquido o solido? Entrambi, cont...
iPhone 17 Pro Max in offerta su Amazon: ...
A Taranto divieto di bici, e-bike e mono...
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: 08:19.


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