Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Recensione realme 16 5G: lo smartphone con Selfie Mirror ha una batteria da 6550mAh
Recensione realme 16 5G: lo smartphone con Selfie Mirror ha una batteria da 6550mAh
realme 16 5G è un nuovo smartphone con sensore Sony IMX 852 da 50MP sul retro e uno specchio selfie fisico integrato nella camera bar, una prima nel segmento di mercato. Batteria da 6550mAh in un corpo da 8,1mm e 183g, certificazione IP69K e ricarica da 45W completano un pacchetto aggressivo per la fascia media, per uno dei prodotti più interessanti del produttore sul piano commerciale
Come rispettare tutte le nuove regole per i monopattini elettrici? La guida per non rischiare sanzioni
Come rispettare tutte le nuove regole per i monopattini elettrici? La guida per non rischiare sanzioni
Sono ormai definitive le nuove norme del Codice della Strada per i monopattini elettrici. Non solo targa e assicurazione, le regole sono tante e riguardano diversi aspetti, vi spieghiamo come evitare sanzioni che possono essere salate
DLSS 4.5: con Dynamic Frame Generation e MFG 6X NVIDIA alza la posta
DLSS 4.5: con Dynamic Frame Generation e MFG 6X NVIDIA alza la posta
DLSS 4.5 introduce Dynamic Multi Frame Generation e MFG 6X, permettendo fino a cinque frame generati per ogni frame renderizzato. I test su Cyberpunk 2077 e 007 First Light mostrano forti incrementi di FPS e riduzione della latenza su RTX 5090 Laptop. Migliorano fluidità, stabilità e qualità visiva.
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 17-02-2005, 16:10   #1
SteR9
Senior Member
 
L'Avatar di SteR9
 
Iscritto dal: Jun 2002
Città: Milano
Messaggi: 959
[C] Liste bidirezionali

ragazzi potreste farmi un esempio di liste bidirezionali?
nn capisco come mi devo comportare nel caso in cui sia il primo elemento, devo associargli null al puntatore all'elemento precedente?
SteR9 è offline   Rispondi citando il messaggio o parte di esso
Old 17-02-2005, 16:27   #2
anx721
Senior Member
 
L'Avatar di anx721
 
Iscritto dal: Oct 2002
Città: Roma
Messaggi: 1502
Re: [C] Liste bidirezionali

Quote:
Originariamente inviato da SteR9
devo associargli null al puntatore all'elemento precedente?
certo
__________________
Sun Certified Java Programmer
EUCIP Core Level Certified

European Certification of Informatics Professionals
anx721 è offline   Rispondi citando il messaggio o parte di esso
Old 17-02-2005, 16:41   #3
SteR9
Senior Member
 
L'Avatar di SteR9
 
Iscritto dal: Jun 2002
Città: Milano
Messaggi: 959
Codice:
typedef struct nodoBi{
       int numero;
       struct nodoBi *pProx;
       struct nodoBi *pPrec;
}nodoBi;

void inserisci_elementi(nodoBi **ppNodo,int elem);
void stampa_elem(nodoBi *pNodo,int contr);
int main()
{
      nodoBi *pTesta;
      pTesta = NULL;
      inserisci_elementi(&pTesta,15);
      inserisci_elementi(&pTesta,3);
      inserisci_elementi(&pTesta,64);
      inserisci_elementi(&pTesta,6);
      inserisci_elementi(&pTesta,34);
      stampa_elem(pTesta,2);
      stampa_elem(pTesta,1);
      system("PAUSE");
      return 0;
}

void stampa_elem(nodoBi *pNodo,int contr){
      nodoBi *Punt;
      Punt = pNodo;
      puts("*****************************************");
      while(Punt != NULL){
            switch (contr){
               case 1:
                     if((Punt->pPrec != NULL) && (Punt->pProx!=NULL)){
                       printf("Precedente: %d  || Corrente: %d || Successivo: %d\n",Punt->pPrec->numero,Punt->numero,Punt->pProx->numero);
                     }
               break;
               case 2:
                     printf("Numero: %d\n",Punt->numero);
               break;
            }
      Punt=Punt->pProx;
      }
}
void inserisci_elementi(nodoBi **ppNodo,int elem){

     nodoBi *Punt,*pPreced,*pProxi;

     pPreced = NULL;
     pProxi = *ppNodo;
     while((pProxi != NULL) && (pProxi->numero < elem)){
       pPreced = pProxi;
       pProxi = pProxi->pProx;
     }
     Punt = (nodoBi*)malloc(sizeof(nodoBi));
     Punt->numero = elem;
     Punt->pProx = pProxi;
     Punt->pPrec = pPreced;

     if(pPreced != NULL){
      pPreced->pProx = Punt;
     }else{
      *ppNodo = Punt;
      Punt->pPrec = NULL;
     }
}
ho provato a fare così però se nn metto l'
if((Punt->pPrec != NULL) && (Punt->pProx!=NULL)){
da errore e esce.. cosa sbaglio?
ciao
SteR9 è offline   Rispondi citando il messaggio o parte di esso
Old 17-02-2005, 16:50   #4
SteR9
Senior Member
 
L'Avatar di SteR9
 
Iscritto dal: Jun 2002
Città: Milano
Messaggi: 959
ho trovato un altro errore se l'elemento quando viene inserito capita in testa e poi viene spostato il suo valore rimarrà null..come risolvo?
SteR9 è offline   Rispondi citando il messaggio o parte di esso
Old 17-02-2005, 16:59   #5
SteR9
Senior Member
 
L'Avatar di SteR9
 
Iscritto dal: Jun 2002
Città: Milano
Messaggi: 959
Quote:
Originariamente inviato da SteR9
ho trovato un altro errore se l'elemento quando viene inserito capita in testa e poi viene spostato il suo valore rimarrà null..come risolvo?
ho provato facendo così nell'else

else{
(*ppNodo)->pPrec = *ppNodo;
*ppNodo = Punt;
Punt->pPrec = NULL;
}

ma non va..HELP!
SteR9 è offline   Rispondi citando il messaggio o parte di esso
Old 17-02-2005, 17:31   #6
Fenomeno85
Senior Member
 
L'Avatar di Fenomeno85
 
Iscritto dal: Jun 2002
Città: Provincia De VaRéSe ~ § ~ Lat.: 45° 51' 7" N Long.: 8° 50' 21" E ~§~ Magica Inter ~ § ~ Detto: A Chi Più Amiamo Meno Dire Sappiamo ~ § ~ ~ § ~ Hobby: Divertimento allo Stato Puro ~ § ~ ~ § ~ You Must Go Out ~ § ~
Messaggi: 8897
Codice:
#include <stdio.h>
#include <stdlib.h>

typedef struct EL {
	int iVal;
	struct EL *pNext;
	struct EL *pPrec;
} Node;

void visualizza (Node *pEl){
	if (pEl==NULL) return;
	printf ("\nElement:\t%d",pEl->iVal);
	visualizza(pEl->pNext);
}

void ins_head (Node **pTesta, int iValue){
	Node *pApp;
	pApp = (Node*)malloc(sizeof(Node));
	pApp->iVal = iValue;
	pApp->pNext = *pTesta;
	pApp->pPrec = NULL;
	*pTesta = pApp;
}

void ins_ord (Node **pTesta, int iValue){
	Node *pApp, *pSup, *pPrec;
	pApp = (Node*)malloc(sizeof(Node));
	pApp->iVal = iValue;
	pSup = *pTesta;
	pPrec = NULL;
	while (pSup!=NULL && pSup->iVal < pApp->iVal){
		pPrec=pSup;
		pSup=pSup->pNext;
	}
	if (pPrec == NULL){
		pApp->pNext = pApp->pPrec = NULL;
		*pTesta = pApp;
	}
	else{
			pPrec->pNext = pApp;
			pApp->pNext = pSup;
			pApp->pPrec = pPrec;
			if (pSup != NULL){
				pSup->pPrec = pApp;
			}
	}
}

int main (void){
	Node *Testa;
	Node *TestaOrdinata;
	TestaOrdinata = NULL;
	Testa = NULL;
	ins_head (&Testa,3);
	ins_head (&Testa,4);
	ins_head (&Testa,5);
	
	ins_ord (&TestaOrdinata,3);
	ins_ord (&TestaOrdinata,4);
	ins_ord (&TestaOrdinata,5);
	

	visualizza (Testa);
	printf ("\n\n");
	visualizza (TestaOrdinata);
	printf ("\n\n");
	system ("PAUSE");
	return (0);
}
~§~ Sempre E Solo Lei ~§~
__________________
Meglio essere protagonisti della propria tragedia che spettatori della propria vita
Si dovrebbe pensare più a far bene che a stare bene: e così si finirebbe anche a star meglio.
Non preoccuparti solo di essere migliore dei tuoi contemporanei o dei tuoi predecessori.Cerca solo di essere migliore di te stesso
Fenomeno85 è offline   Rispondi citando il messaggio o parte di esso
Old 17-02-2005, 18:15   #7
SteR9
Senior Member
 
L'Avatar di SteR9
 
Iscritto dal: Jun 2002
Città: Milano
Messaggi: 959
mi perde il primo elemento così
Codice:
void inserisci_elementi(nodoBi **ppNodo,int elem){

     nodoBi *Punt,*pPreced,*pProxi;

     pPreced = NULL;
     pProxi = *ppNodo;
     while((pProxi != NULL) && (pProxi->numero < elem)){
       pPreced = pProxi;
       pProxi = pProxi->pProx;
     }
     Punt = (nodoBi*)malloc(sizeof(nodoBi));
     Punt->numero = elem;
     Punt->pProx = pProxi;
     Punt->pPrec = pPreced;

    if (pPreced == NULL){
		Punt->pProx = Punt->pPrec = NULL;
		*ppNodo = Punt;
	}
	else{
			pPreced->pProx = Punt;
			Punt->pProx = pProxi;
			Punt->pPrec = pPreced;
			if (pProxi != NULL){
				pProxi->pPrec = Punt;
			}
	}

}
SteR9 è offline   Rispondi citando il messaggio o parte di esso
Old 17-02-2005, 18:33   #8
Fenomeno85
Senior Member
 
L'Avatar di Fenomeno85
 
Iscritto dal: Jun 2002
Città: Provincia De VaRéSe ~ § ~ Lat.: 45° 51' 7" N Long.: 8° 50' 21" E ~§~ Magica Inter ~ § ~ Detto: A Chi Più Amiamo Meno Dire Sappiamo ~ § ~ ~ § ~ Hobby: Divertimento allo Stato Puro ~ § ~ ~ § ~ You Must Go Out ~ § ~
Messaggi: 8897
scusa mi son dimenticato di postarti l'ultima versione che avevo fatto
Codice:
#include <stdio.h>
#include <stdlib.h>

typedef struct EL {
	int iVal;
	struct EL *pNext;
	struct EL *pPrec;
} Node;

void visualizza (Node *pEl){
	if (pEl==NULL) return;
	printf ("\nElement:\t%d",pEl->iVal);
	visualizza(pEl->pNext);
}

void ins_head (Node **pTesta, int iValue){
	Node *pApp;
	pApp = (Node*)malloc(sizeof(Node));
	pApp->iVal = iValue;
	pApp->pNext = *pTesta;
	pApp->pPrec = NULL;
	*pTesta = pApp;
}

void ins_ord (Node **pTesta, int iValue){
	Node *pApp, *pSup, *pPrec;
	pApp = (Node*)malloc(sizeof(Node));
	pApp->iVal = iValue;
	pSup = *pTesta;
	pPrec = NULL;
	while (pSup!=NULL && pSup->iVal < pApp->iVal){
		pPrec=pSup;
		pSup=pSup->pNext;
	}
	if (pPrec == NULL){
		pApp->pNext = *pTesta;
		pApp->pPrec = NULL;
		*pTesta = pApp;
	}
	else{
			pPrec->pNext = pApp;
			pApp->pNext = pSup;
			pApp->pPrec = pPrec;
			if (pSup != NULL){
				pSup->pPrec = pApp;
			}
	}
}

int main (void){
	Node *Testa;
	Node *TestaOrdinata;
	TestaOrdinata = NULL;
	Testa = NULL;
	ins_head (&Testa,3);
	ins_head (&Testa,4);
	ins_head (&Testa,5);
	
	ins_ord (&TestaOrdinata,3);
	ins_ord (&TestaOrdinata,2);
	ins_ord (&TestaOrdinata,4);
	ins_ord (&TestaOrdinata,5);
	

	visualizza (Testa);
	printf ("\n\n");
	visualizza (TestaOrdinata);
	printf ("\n\n");
	system ("PAUSE");
	return (0);
}
~§~ Sempre E Solo Lei ~§~
__________________
Meglio essere protagonisti della propria tragedia che spettatori della propria vita
Si dovrebbe pensare più a far bene che a stare bene: e così si finirebbe anche a star meglio.
Non preoccuparti solo di essere migliore dei tuoi contemporanei o dei tuoi predecessori.Cerca solo di essere migliore di te stesso
Fenomeno85 è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Recensione realme 16 5G: lo smartphone con Selfie Mirror ha una batteria da 6550mAh Recensione realme 16 5G: lo smartphone con Selfi...
Come rispettare tutte le nuove regole per i monopattini elettrici? La guida per non rischiare sanzioni Come rispettare tutte le nuove regole per i mono...
DLSS 4.5: con Dynamic Frame Generation e MFG 6X NVIDIA alza la posta DLSS 4.5: con Dynamic Frame Generation e MFG 6X ...
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 ...
FASTCloud Open Source: un cloud sovrano ...
AMD non lascia spazio a Intel: la top 15...
iPhone 17 torna protagonista su Amazon: ...
PowerToys si aggiorna alla versione 0.10...
La nuova Audi Q7 proietta le frecce sull...
Framework blocca tutto: Laptop 13 Pro no...
SSD, Biwin investe oltre metà del...
Samsung Trend Radar 2026: smartphone e s...
Enel entra nella telefonia mobile: il vi...
Arriva il menu contestuale aggiornato di...
GM punta sulle batterie al sodio per lo ...
Instagram amplia il controllo sull'algor...
Jason Wild: "Siamo bravissimi a ris...
Razer BlackShark V2 X a 34,99€: cuffie e...
d-Matrix avvia la produzione di Corsair:...
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: 19:23.


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