Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Antigravity A1: drone futuristico per riprese a 360° in 8K con qualche lacuna da colmare
Antigravity A1: drone futuristico per riprese a 360° in 8K con qualche lacuna da colmare
Abbiamo messo alla prova il drone Antigravity A1 capace di riprese in 8K a 360° che permette un reframe in post-produzione ad eliche ferme. Il concetto è molto valido, permette al pilota di concentrarsi sul volo e le manovre in tutta sicurezza e decidere con tutta tranquillità come gestire le riprese. La qualità dei video, tuttavia, ha bisogno di uno step in più per essere competitiva
Sony Alpha 7 V, anteprima e novità della nuova 30fps, che tende la mano anche ai creator
Sony Alpha 7 V, anteprima e novità della nuova 30fps, che tende la mano anche ai creator
Dopo oltre 4 anni si rinnova la serie Sony Alpha 7 con la quinta generazione, che porta in dote veramente tante novità a partire dai 30fps e dal nuovo sensore partially stacked da 33Mpixel. L'abbiamo provata per un breve periodo, ecco come è andata dopo averla messa alle strette.
realme GT 8 Pro Dream Edition: prestazioni da flagship e anima racing da F1
realme GT 8 Pro Dream Edition: prestazioni da flagship e anima racing da F1
realme e Aston Martin Aramco F1 Team si sono (ri)unite dando alla vita un flagship con chip Snapdragon 8 Elite Gen 5 e design esclusivo ispirato alle monoposto di Formula 1. La Dream Edition introduce la nuova colorazione Lime Essence abbinata al tradizionale Aston Martin Racing Green, decorazioni intercambiabili personalizzate e una confezione a tema F1, intorno a uno smartphone dall'ottima dotazione tecnica con batteria da 7000mAh ricaricabile a 120W e isola fotografica intercambiabile
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 17-02-2005, 17: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, 17: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, 17: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, 17: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, 17: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, 18: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: 8896
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, 19: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, 19: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: 8896
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


Antigravity A1: drone futuristico per riprese a 360° in 8K con qualche lacuna da colmare Antigravity A1: drone futuristico per riprese a ...
Sony Alpha 7 V, anteprima e novità della nuova 30fps, che tende la mano anche ai creator Sony Alpha 7 V, anteprima e novità della ...
realme GT 8 Pro Dream Edition: prestazioni da flagship e anima racing da F1 realme GT 8 Pro Dream Edition: prestazioni da fl...
OVHcloud Summit 2025: le novità del cloud europeo tra sovranità, IA e quantum OVHcloud Summit 2025: le novità del cloud...
Un mostro da MSI: QD-OLED WQHD a 500 Hz con AI Care e DisplayPort 2.1a Un mostro da MSI: QD-OLED WQHD a 500 Hz con AI C...
iPhone Air va in sconto: il nuovo iPhone...
Polaroid Now Gen 3 torna di moda: la fot...
Fallout 76: l'aggiornamento più g...
Prezzo folle per il top OLED da gaming: ...
Un nuovo processo antitrust per Apple in...
Amazon abbassa il prezzo delle AirPods 4...
Due super offerte Amazon: PC Desktop con...
Apple AirTag: il pacchetto da 4 ora a so...
La Cina senza NVIDIA: Moore Threads e Ca...
Un bel portatile potente in offerta: Ace...
Si mimetizza tra due altoparlanti, ma &e...
Clair Obscur Expedition 33: il lancio su...
Ci risiamo, la censura colpisce Roblox: ...
Gli iPhone 17 Pro perdono una funzione d...
Windows 11 non cresce e riduce la sua qu...
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: 10:06.


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