Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Recensione vivo X300 Pro: è ancora lui il re della fotografia mobile, peccato per la batteria
Recensione vivo X300 Pro: è ancora lui il re della fotografia mobile, peccato per la batteria
vivo X300 Pro rappresenta un'evoluzione misurata della serie fotografica del produttore cinese, con un sistema di fotocamere migliorato, chipset Dimensity 9500 di ultima generazione e l'arrivo dell'interfaccia OriginOS 6 anche sui modelli internazionali. La scelta di limitare la batteria a 5.440mAh nel mercato europeo, rispetto ai 6.510mAh disponibili altrove, fa storcere un po' il naso
Lenovo Legion Go 2: Ryzen Z2 Extreme e OLED 8,8'' per spingere gli handheld gaming PC al massimo
Lenovo Legion Go 2: Ryzen Z2 Extreme e OLED 8,8'' per spingere gli handheld gaming PC al massimo
Lenovo Legion Go 2 è la nuova handheld PC gaming con processore AMD Ryzen Z2 Extreme (8 core Zen 5/5c, GPU RDNA 3.5 16 CU) e schermo OLED 8,8" 1920x1200 144Hz. È dotata anche di controller rimovibili TrueStrike con joystick Hall effect e una batteria da 74Wh. Rispetto al dispositivo che l'ha preceduta, migliora ergonomia e prestazioni a basse risoluzioni, ma pesa 920g e costa 1.299€ nella configurazione con 32GB RAM/1TB SSD e Z2 Extreme
AWS re:Invent 2025: inizia l'era dell'AI-as-a-Service con al centro gli agenti
AWS re:Invent 2025: inizia l'era dell'AI-as-a-Service con al centro gli agenti
A re:Invent 2025, AWS mostra un’evoluzione profonda della propria strategia: l’IA diventa una piattaforma di servizi sempre più pronta all’uso, con agenti e modelli preconfigurati che accelerano lo sviluppo, mentre il cloud resta la base imprescindibile per governare dati, complessità e lock-in in uno scenario sempre più orientato all’hybrid cloud
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 14-09-2004, 20:51   #1
TorpedoBlu
Senior Member
 
L'Avatar di TorpedoBlu
 
Iscritto dal: Sep 2003
Città: Milano
Messaggi: 4623
[C] puntatori liste e via dicendo.....sono ottuso

devo fare un progettino in C per l'uni, nello studio dopo le strutture sono fermo alle liste semplici...non mi persuado sulla loro implementazione....forse perchè non mi entra in testa luso dei puntatori (li ho capiti, ma forse non digeriti) please! se non capisco le liste non capirò le liste di adiacenze (che sono la base del mio progettino, visto che devo usare una matrice NxN e un array bidimensionale sarebbe poco furbo)
__________________
Ho trattato con : lahiri, czame, RC, allXXX, dfruggeri, JMM, Paperone, xej, Pappez, iperfly, Red81, Playmake, ryan78, Rob66, XP2200, Peach1200, faberjack, Stewie82, supermario_bros, hft500, Axelscorpio, pipes lee, Piccolospazio, RohanKish, miki66, kabira85
TorpedoBlu è offline   Rispondi citando il messaggio o parte di esso
Old 15-09-2004, 04:33   #2
Gen.Web
Senior Member
 
L'Avatar di Gen.Web
 
Iscritto dal: Dec 2002
Città: Loano (SV)
Messaggi: 1172
Re: [C] puntatori liste e via dicendo.....sono ottuso

Quote:
Originariamente inviato da TorpedoBlu
devo fare un progettino in C per l'uni, nello studio dopo le strutture sono fermo alle liste semplici...non mi persuado sulla loro implementazione....forse perchè non mi entra in testa luso dei puntatori (li ho capiti, ma forse non digeriti) please! se non capisco le liste non capirò le liste di adiacenze (che sono la base del mio progettino, visto che devo usare una matrice NxN e un array bidimensionale sarebbe poco furbo)
allora...faccio direttamente l'esempio di una lista (gli stack e le code non sono altro che liste particolari).
Metti di avere due strutture così fatte:

Quote:
struct Node {
int x;
int y;
Node *next;
};

struct List {
Node *itshead; //Nodo di testa
Node *itstail; //Nodo di coda
};
La lista è appunto una lista di "nodi", in questo caso una lista di oggetti di tipo Node. Una lista implica che ci sia un nodo di testa e uno di coda, con in mezzo altri nodi tutti connessi uno all'altro tramite il puntatore Node *next (che indica il nodo successivo a quello corrente).

Quote:
int main() {

Node *K= new Node; // Creiamo un "nodo" (un oggetto) di tipo Node nella heap
Node *S=new Node; // Creiamo un secondo nodo
Node *G=new Node; // Creiamo un terzo nodo
List *Lista=new List; // Creiamo la lista che conterrà i vari nodi
Lista->itshead=K; // Mettiamo come nodo in testa alla lista K
Lista->itshead->next=S; // Il nodo successivo a head impongo che sia S
S->next=G; // Il nodo successivo a S è G
Lista->itstail=S; // S è anche l'ultimo nodo che abbiamo, quindi è la coda della lista
}
Anche se neanche una capra implementerebbe una lista in questo modo, spero sia facile da capire.
Alla fine ti ritrovi ad avere proprio una lista: tutti i nodi sono collegati tra loro, da head a tail.
Infatti ai nodi si può accedere così: Lista->itshead (sarebbe K), Lista->itshead->next(sarebbe S), Lista->itshead->next->next (sarebbe G).
Per esempio Lista->itshead->next->next->x (stessa cosa: Lista->tail->x) ci darebbe il contenuto del campo x dell'oggetto G.

Spero sia stato chiaro.
Gen.Web è offline   Rispondi citando il messaggio o parte di esso
Old 15-09-2004, 16:05   #3
TorpedoBlu
Senior Member
 
L'Avatar di TorpedoBlu
 
Iscritto dal: Sep 2003
Città: Milano
Messaggi: 4623
allora, io non conosco il C, ma una cosa del tipo
Node x = new Node

mi sembra più una dichiarazione java che C, sei sicuro? io devo programmare rigorosamente in C con lo standard ANSI ed il compilatore gcc.

come hai implementato il codice è diverso dal mio libro di testo, lui implementa tutto usando un unica struttura "list" e non 2....
__________________
Ho trattato con : lahiri, czame, RC, allXXX, dfruggeri, JMM, Paperone, xej, Pappez, iperfly, Red81, Playmake, ryan78, Rob66, XP2200, Peach1200, faberjack, Stewie82, supermario_bros, hft500, Axelscorpio, pipes lee, Piccolospazio, RohanKish, miki66, kabira85
TorpedoBlu è offline   Rispondi citando il messaggio o parte di esso
Old 15-09-2004, 16:51   #4
Zeus84
Senior Member
 
Iscritto dal: Dec 2002
Città: Bologna
Messaggi: 483
Vediamo se posso aiutarti io visto che ci ho sbattuto la testa a lungo anch'io....
Proviamo a fare una lista semplice, in cui ogni nodo contiene un intero e un puntatore naturalmente ad un altro nodo...
Dichiariamo la struttura

struct nodo{
int valore;
struct nodo *next;
}

typedef struct nodo nodo;

In queste due righe credo non ci siano problemi. Ora dovresti precisarmi qual'è il tuo problema per andare avanti..potri scrivere molte righe di codice che sono però totalmente inutili....
__________________
Acer TravelMate 8103Wlmi
Zeus84 è offline   Rispondi citando il messaggio o parte di esso
Old 15-09-2004, 17:55   #5
cionci
Senior Member
 
L'Avatar di cionci
 
Iscritto dal: Apr 2000
Città: Vicino a Montecatini(Pistoia) Moto:Kawasaki Ninja ZX-9R Scudetti: 29
Messaggi: 53971
Quote:
Originariamente inviato da TorpedoBlu
allora, io non conosco il C, ma una cosa del tipo
Quello sopra è tutto C++

Devi mettere la porola struct davanti ogni volta che usi il nome di una struct... Per evitare questo devi usare typedef come spiegto sopra

Per l'allocazione non si usa la new, ma malloc...una funzione definita in stdlib.h...

La malloc si usa così:

pippo *p;

p = (pippo *) malloc(sizeof(pippo));

p->membro per accedere ai membri della struct puntata da p...

Per liberare la memoria allocata:

free(p);

Ultima modifica di cionci : 15-09-2004 alle 17:58.
cionci è offline   Rispondi citando il messaggio o parte di esso
Old 15-09-2004, 18:30   #6
Gen.Web
Senior Member
 
L'Avatar di Gen.Web
 
Iscritto dal: Dec 2002
Città: Loano (SV)
Messaggi: 1172
scusate, ma sn abituato al c++. E cmq l'obbiettivo era capire le liste, no?
Gen.Web è offline   Rispondi citando il messaggio o parte di esso
Old 15-09-2004, 19:49   #7
TorpedoBlu
Senior Member
 
L'Avatar di TorpedoBlu
 
Iscritto dal: Sep 2003
Città: Milano
Messaggi: 4623
Quote:
Originariamente inviato da Zeus84
Vediamo se posso aiutarti io visto che ci ho sbattuto la testa a lungo anch'io....
Proviamo a fare una lista semplice, in cui ogni nodo contiene un intero e un puntatore naturalmente ad un altro nodo...
Dichiariamo la struttura

struct nodo{
int valore;
struct nodo *next;
}

typedef struct nodo nodo;

In queste due righe credo non ci siano problemi. Ora dovresti precisarmi qual'è il tuo problema per andare avanti..potri scrivere molte righe di codice che sono però totalmente inutili....
dunque, qui ci sono, ma poi non so continuare, come faccio ad esempio a riempire una lista con degli elementi? e se voglio diciamo fare operazioni su tale lista? mi fate esempi?
__________________
Ho trattato con : lahiri, czame, RC, allXXX, dfruggeri, JMM, Paperone, xej, Pappez, iperfly, Red81, Playmake, ryan78, Rob66, XP2200, Peach1200, faberjack, Stewie82, supermario_bros, hft500, Axelscorpio, pipes lee, Piccolospazio, RohanKish, miki66, kabira85
TorpedoBlu è offline   Rispondi citando il messaggio o parte di esso
Old 15-09-2004, 20:10   #8
cionci
Senior Member
 
L'Avatar di cionci
 
Iscritto dal: Apr 2000
Città: Vicino a Montecatini(Pistoia) Moto:Kawasaki Ninja ZX-9R Scudetti: 29
Messaggi: 53971
Ad esempio:

Inserimento in testa (con la struttura sopra)...

Codice:
nodo *inserisci_in_testa(nodo *testa, in valore)
{
    nodo *tmp = (nodo *) malloc (sizeof(nodo));
    tmp->valore = valore; /*equivale a (*tmp).valore = valore;*/
    tmp->next = testa;
    return tmp;
}

...
nodo *lista = NULL; /*lista vuota*/
....
....
lista = inserisci_in_testa(lista, 10);
lista = inserisci_in_testa(lista, 8);
lista = inserisci_in_testa(lista, 80);
....

Ultima modifica di cionci : 15-09-2004 alle 21:53.
cionci è offline   Rispondi citando il messaggio o parte di esso
Old 15-09-2004, 21:10   #9
TorpedoBlu
Senior Member
 
L'Avatar di TorpedoBlu
 
Iscritto dal: Sep 2003
Città: Milano
Messaggi: 4623
ok, in questo caso creo la lista vuota e la riempio, quali altre proprietà\operazioni? ad esempio se voglio cercare il dato + piccolo?
__________________
Ho trattato con : lahiri, czame, RC, allXXX, dfruggeri, JMM, Paperone, xej, Pappez, iperfly, Red81, Playmake, ryan78, Rob66, XP2200, Peach1200, faberjack, Stewie82, supermario_bros, hft500, Axelscorpio, pipes lee, Piccolospazio, RohanKish, miki66, kabira85
TorpedoBlu è offline   Rispondi citando il messaggio o parte di esso
Old 15-09-2004, 21:35   #10
TorpedoBlu
Senior Member
 
L'Avatar di TorpedoBlu
 
Iscritto dal: Sep 2003
Città: Milano
Messaggi: 4623
Codice:
#include<stdio.h>
#include<stdlib.h>


int main(void){


struct nodo{ 
int valore; 
struct nodo *next; 
} 



struct nodo *inserisciInTesta(struct nodo *testa, int valore){
    struct nodo *tmp = (nodo *) malloc (sizeof(testa));
    tmp->valore = valore; /*equivale a (*tmp).valore = valore;*/
    tmp->next = testa;
    return tmp;
}


struct nodo *lista = NULL; /*lista vuota*/
lista = inserisciInTesta(lista, 10);
lista = inserisciInTesta(lista, 8);
lista = inserisciInTesta(lista, 80);

return 0;
}
NON FUNZIONA
__________________
Ho trattato con : lahiri, czame, RC, allXXX, dfruggeri, JMM, Paperone, xej, Pappez, iperfly, Red81, Playmake, ryan78, Rob66, XP2200, Peach1200, faberjack, Stewie82, supermario_bros, hft500, Axelscorpio, pipes lee, Piccolospazio, RohanKish, miki66, kabira85
TorpedoBlu è offline   Rispondi citando il messaggio o parte di esso
Old 15-09-2004, 21:53   #11
cionci
Senior Member
 
L'Avatar di cionci
 
Iscritto dal: Apr 2000
Città: Vicino a Montecatini(Pistoia) Moto:Kawasaki Ninja ZX-9R Scudetti: 29
Messaggi: 53971
Avevo sbagliato a scrivere la malloc...

Se non usi il typedef devi scrivere così:

struct nodo *tmp = (struct nodo *) malloc (sizeof(struct nodo));
cionci è offline   Rispondi citando il messaggio o parte di esso
Old 15-09-2004, 21:58   #12
TorpedoBlu
Senior Member
 
L'Avatar di TorpedoBlu
 
Iscritto dal: Sep 2003
Città: Milano
Messaggi: 4623
15 C:\Documents and Settings\Giamma\Desktop\liste.c two or more data types in declaration of `inserisciInTesta'


ho messo la riga della malloc, ma non funziona ancora
__________________
Ho trattato con : lahiri, czame, RC, allXXX, dfruggeri, JMM, Paperone, xej, Pappez, iperfly, Red81, Playmake, ryan78, Rob66, XP2200, Peach1200, faberjack, Stewie82, supermario_bros, hft500, Axelscorpio, pipes lee, Piccolospazio, RohanKish, miki66, kabira85
TorpedoBlu è offline   Rispondi citando il messaggio o parte di esso
Old 15-09-2004, 23:52   #13
cionci
Senior Member
 
L'Avatar di cionci
 
Iscritto dal: Apr 2000
Città: Vicino a Montecatini(Pistoia) Moto:Kawasaki Ninja ZX-9R Scudetti: 29
Messaggi: 53971


Codice:
struct nodo{ 
int valore; 
struct nodo *next; 
} 

struct nodo *inserisciInTesta(struct nodo *testa, int valore){
    struct nodo *tmp = (struct nodo *) malloc (sizeof(struct nodo));
    tmp->valore = valore; /*equivale a (*tmp).valore = valore;*/
    tmp->next = testa;
    return tmp;
}




int main(void){


struct nodo *lista = NULL; /*lista vuota*/
lista = inserisciInTesta(lista, 10);
lista = inserisciInTesta(lista, 8);
lista = inserisciInTesta(lista, 80);

return 0;
}
cionci è offline   Rispondi citando il messaggio o parte di esso
Old 16-09-2004, 10:20   #14
TorpedoBlu
Senior Member
 
L'Avatar di TorpedoBlu
 
Iscritto dal: Sep 2003
Città: Milano
Messaggi: 4623
13 C:\Documents and Settings\Giamma\Desktop\liste.c
: two or more data types in declaration of `inserisciInTesta'

ancora un errore
__________________
Ho trattato con : lahiri, czame, RC, allXXX, dfruggeri, JMM, Paperone, xej, Pappez, iperfly, Red81, Playmake, ryan78, Rob66, XP2200, Peach1200, faberjack, Stewie82, supermario_bros, hft500, Axelscorpio, pipes lee, Piccolospazio, RohanKish, miki66, kabira85
TorpedoBlu è offline   Rispondi citando il messaggio o parte di esso
Old 16-09-2004, 11:24   #15
Zeus84
Senior Member
 
Iscritto dal: Dec 2002
Città: Bologna
Messaggi: 483
Quote:
Originariamente inviato da TorpedoBlu
13 C:\Documents and Settings\Giamma\Desktop\liste.c
: two or more data types in declaration of `inserisciInTesta'

ancora un errore
non riesco a vedere l'errore....

comunque visto che state pubblicando le operazioni da fare sulla lista, questa ad esempio la stampa

void stampa_lista(struct nodo* start){
if (start!=NULL){
do
printf("%d", start->valore);
while((start=start->next)!=NULL);
}
}
__________________
Acer TravelMate 8103Wlmi
Zeus84 è offline   Rispondi citando il messaggio o parte di esso
Old 16-09-2004, 11:44   #16
TorpedoBlu
Senior Member
 
L'Avatar di TorpedoBlu
 
Iscritto dal: Sep 2003
Città: Milano
Messaggi: 4623
dunque, come mai mi da quel mex di errore? chi mi aiuta?
__________________
Ho trattato con : lahiri, czame, RC, allXXX, dfruggeri, JMM, Paperone, xej, Pappez, iperfly, Red81, Playmake, ryan78, Rob66, XP2200, Peach1200, faberjack, Stewie82, supermario_bros, hft500, Axelscorpio, pipes lee, Piccolospazio, RohanKish, miki66, kabira85
TorpedoBlu è offline   Rispondi citando il messaggio o parte di esso
Old 16-09-2004, 11:50   #17
Zeus84
Senior Member
 
Iscritto dal: Dec 2002
Città: Bologna
Messaggi: 483
a volte non si sa..comunque prova a scrivere

(struct nodo *) inse....

ovvero metti tra () il tipo di ritorno della funzione
__________________
Acer TravelMate 8103Wlmi
Zeus84 è offline   Rispondi citando il messaggio o parte di esso
Old 16-09-2004, 12:03   #18
TorpedoBlu
Senior Member
 
L'Avatar di TorpedoBlu
 
Iscritto dal: Sep 2003
Città: Milano
Messaggi: 4623
provato... praticamente non prende "struct nodo" come dichiarazione della funzione....
__________________
Ho trattato con : lahiri, czame, RC, allXXX, dfruggeri, JMM, Paperone, xej, Pappez, iperfly, Red81, Playmake, ryan78, Rob66, XP2200, Peach1200, faberjack, Stewie82, supermario_bros, hft500, Axelscorpio, pipes lee, Piccolospazio, RohanKish, miki66, kabira85
TorpedoBlu è offline   Rispondi citando il messaggio o parte di esso
Old 16-09-2004, 12:15   #19
Zeus84
Senior Member
 
Iscritto dal: Dec 2002
Città: Bologna
Messaggi: 483
Quote:
Originariamente inviato da TorpedoBlu
provato... praticamente non prende "struct nodo" come dichiarazione della funzione....
ma funziona o no? ti continua a segnalare errori?
__________________
Acer TravelMate 8103Wlmi
Zeus84 è offline   Rispondi citando il messaggio o parte di esso
Old 16-09-2004, 15:56   #20
cionci
Senior Member
 
L'Avatar di cionci
 
Iscritto dal: Apr 2000
Città: Vicino a Montecatini(Pistoia) Moto:Kawasaki Ninja ZX-9R Scudetti: 29
Messaggi: 53971
Manca il ; dopo la dichiarazione della struct...

Ora non è che possiamo dirti quali sono le possibili operazioni su una lista...perchè bene o male ci puoi fare tutto...

Sulle liste puoi operare su un singolo elemento (anche non in testa, ricercando ad esempio il valore) in maniera iterativa...oppure in maniera ricorsiva...

Ti faccio vedere come si opera in entrambi i modi...
Codice:
#include <stdio.h>
#include <stdlib.h>
#include <memory.h>

struct nodo{ 
int valore; 
struct nodo *next; 
};

struct nodo *inserisci_in_testa(struct nodo *testa, int valore)
{
    struct nodo *tmp = (struct nodo *) malloc (sizeof(struct nodo));
    tmp->valore = valore; /*equivale a (*tmp).valore = valore;*/
    tmp->next = testa;
    return tmp;
}

void stampa_lista(struct nodo* start)
{
	if (start!=NULL)
	{
		do
			printf("%d\n", start->valore);
		while((start=start->next)!=NULL);
	}
}

struct nodo *elimina_elemento(struct nodo *elem)
{
	struct nodo *tmp;
	if(elem) /*equivale a if(elem != NULL)*/
	{
		tmp = elem;
		elem = elem->next;
		free(tmp);
	}
	return elem;
}


void svuota_lista(struct nodo *testa)
{
	while(testa)
		testa = elimina_elemento(testa);
}

void svuota_lista2(struct nodo *elem)
{
	if(elem)
		svuota_lista2(elimina_elemento(elem));
}

int main(void)
{


	struct nodo *lista = NULL; /*lista vuota*/
	lista = inserisci_in_testa(lista, 10);
	lista = inserisci_in_testa(lista, 8);
	lista = inserisci_in_testa(lista, 10);
	lista = inserisci_in_testa(lista, 80);
	lista = inserisci_in_testa(lista, 8);
	lista = inserisci_in_testa(lista, 80);
	lista = inserisci_in_testa(lista, 8);
	lista = inserisci_in_testa(lista, 80);
	lista = inserisci_in_testa(lista, 10);
	lista = inserisci_in_testa(lista, 8);
	lista = inserisci_in_testa(lista, 10);
	lista = inserisci_in_testa(lista, 80);

	lista = elimina_elemento(lista); /*elimino l'elemento in testa: 80*/

	stampa_lista(lista);

	svuota_lista(lista);

	return 0;
}
cionci è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Recensione vivo X300 Pro: è ancora lui il re della fotografia mobile, peccato per la batteria Recensione vivo X300 Pro: è ancora lui il...
Lenovo Legion Go 2: Ryzen Z2 Extreme e OLED 8,8'' per spingere gli handheld gaming PC al massimo Lenovo Legion Go 2: Ryzen Z2 Extreme e OLED 8,8'...
AWS re:Invent 2025: inizia l'era dell'AI-as-a-Service con al centro gli agenti AWS re:Invent 2025: inizia l'era dell'AI-as-a-Se...
Cos'è la bolla dell'IA e perché se ne parla Cos'è la bolla dell'IA e perché se...
BOOX Palma 2 Pro in prova: l'e-reader diventa a colori, e davvero tascabile BOOX Palma 2 Pro in prova: l'e-reader diventa a ...
Il nuovo OnePlus Nord 6 è vicino al debu...
Tesla svela i risultati del Q4: conferma...
Nuova rimodulazione da Fastweb: fino a 3...
La NVIDIA RTX 5090 potrebbe presto costa...
ASUS non produrrà più smar...
CoopVoce sta per lanciare il 5G: ecco qu...
Factorial, azienda di batterie allo stat...
Le specifiche fuori di testa della Yangw...
I numeri incredibili di Xiaomi: nel 2025...
In Cina è pronto il parco fotovol...
Neuralink accelera: produzione di massa ...
Starlink abbassa l'orbita di migliaia di...
Dal MIT una nuova batteria per auto elet...
Adam Mosseri parla di IA su Instagram: l...
Suonerie personalizzate e Tone Store: il...
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: 18:17.


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