Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Corsair Vanguard Air 99 Wireless: non si era mai vista una tastiera gaming così professionale
Corsair Vanguard Air 99 Wireless: non si era mai vista una tastiera gaming così professionale
Nelle ultime settimane abbiamo provato la Corsair Vanguard Air 99 Wireless, una tastiera tecnicamente da gaming, ma che in realtà offre un ampio ventaglio di possibilità anche al di fuori delle sessioni di gioco. Flessibilità e funzionalità sono le parole d'ordine di una periferica che si rivolge a chi cerca un prodotto capace di adattarsi a ogni esigenza e ogni piattaforma
Ecovacs DEEBOT T90 PRO OMNI: ora il rullo di lavaggio è ampio
Ecovacs DEEBOT T90 PRO OMNI: ora il rullo di lavaggio è ampio
DEEBOT T90 PRO OMNI abbina un sistema di aspirazione basato su tecnologia BLAST ad un rullo di lavaggio dei pavimenti dalla larghezza elevata, capace di trattare al meglio le superfici di casa minimizzando i tempi di lavoro. Un robot completo che riesce anche ad essere sottile e garantire automazione ed efficienza nelle operazioni di pulizia di casa
Recensione Samsung Galaxy S26 Ultra: finalmente qualcosa di nuovo
Recensione Samsung Galaxy S26 Ultra: finalmente qualcosa di nuovo
Per diversi giorni il Galaxy S26 Ultra di Samsung è stato il nostro compagno di vita. Oltre alle conferme del colosso coreano come la qualità del display e una suite AI senza rivali, arriva il Privacy Display, un unicum nel mondo smartphone. Ci sono ancora alcuni gap che non sono riusciti a colmare lato batteria e fotocamera, seppur con alcuni miglioramenti.
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 31-03-2007, 12:17   #1
lucas87
Bannato
 
Iscritto dal: Oct 2006
Messaggi: 170
[C] Liste circolari

Salve ho un problema con le liste circolari.
Praticamente per la ricerca ho implementato la seguente funzione:

Codice HTML:
struct list *cerca(struct list *L, int x)
{
	struct list *L2 = L;

	/* se la lista è vuota, restituisce NULL  */
	if (L == NULL) return NULL;

	/* per ogni elemento della lista */
	do
	{
		if (L2->el == x) return L2;

		/* elemento successivo */
		L2 = L2->next;
	} while(L2 != L);

	return NULL;
}
Quindi la lista passata alla funzione è L, poi faccio un nuovo puntatore alla lista L che si chiama L2 e effettuo la ricerca finche L!=L2, dove però L2 dovrebbe partire a puntare al primo elemento e L dovrebbe rimanere fisso a puntare all'ultimo elemento.

COme faccio a farlo puntare all'ultimo elemento?

Grazie in anticipo. se non vi è chiaro qualcosa contattatemi, sono sempre connesso.
lucas87 è offline   Rispondi citando il messaggio o parte di esso
Old 31-03-2007, 13:07   #2
lucas87
Bannato
 
Iscritto dal: Oct 2006
Messaggi: 170
Help please!!!
lucas87 è offline   Rispondi citando il messaggio o parte di esso
Old 31-03-2007, 16:31   #3
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
Mi sembra che vada benissimo così come è scritto..
L punta al primo elemento da controllare, ma è anche il primo elemento già controllato nella ricerca
Infatti L2 parte da L e quando ritorna (la lista è circolare) ad L significa che hai controllato tutti gli elementi ed il ciclo finisce correttamente.
cionci è offline   Rispondi citando il messaggio o parte di esso
Old 31-03-2007, 17:07   #4
lucas87
Bannato
 
Iscritto dal: Oct 2006
Messaggi: 170
giusto, non ci avevo pensato che comuqnue sarebbe arrivato a L lo stesso, il problema è che nella fase di esecuzione crasha tutto.
lucas87 è offline   Rispondi citando il messaggio o parte di esso
Old 31-03-2007, 17:19   #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
Ad occhio non è quello il codice che ti fa crashare... Chiaramente se a quel codice gli passi una lista non circolare ti crasha...
cionci è offline   Rispondi citando il messaggio o parte di esso
Old 31-03-2007, 17:21   #6
lucas87
Bannato
 
Iscritto dal: Oct 2006
Messaggi: 170
Io gli ho passato una lista concatenata, perchè pensavo che si dichiarassero =.

posto tutto il prog, vedi se la lista che gli passo è giusta o no:

Codice HTML:
#include<stdio.h>
#include<stdlib.h>

struct list {
       int el;
       struct list *next;
};


typedef struct list ELEMENT;
typedef ELEMENT *LINK;

LINK carica(LINK,int);
LINK cerca(LINK,int);

int main (void) {
    LINK L;
    int n_el,x;
    printf("Inserisci numero elementi da inserire");
    scanf("%d",&n_el);
    carica(L,n_el);
    printf("Inserisci l'elemento da cercare");
    scanf("%d",&x);
    if(x == cerca(L,x)) printf("Elemento %d presente nella lista",x);

    system ("PAUSE");
    return 0;
}


/*INSERISCE N ELEMENTI IN UNA LISTA CONCATENATA CIRCOLARE*/
LINK carica(LINK L, int n){
     if (n==0) return NULL;
     else {
          L=malloc(sizeof(ELEMENT));
          printf("inserisci l' elemento nella lista\n");
          scanf("%d",&L->el);
          L->next=carica(L,n-1);
          return L;
     }
}

/*CERCA UN ELEMENTO IN UNA LISTA CONCATENATA CIRCOLARE*/
LINK cerca(LINK L, int x)
{
	LINK L2 = L;

	/* se la lista è vuota, restituisce NULL  */
	if (L == NULL) return NULL;

	/* per ogni elemento della lista */
	do
	{
		if (L2->el == x) return L2;

		/* elemento successivo */
		L2 = L2->next;
	} while(L2 != L);

	return NULL;
}

grazie
lucas87 è offline   Rispondi citando il messaggio o parte di esso
Old 31-03-2007, 17:28   #7
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
La differenza fra una lista concatenata ed una lista circolare è che in quella circolare l'ultimo elemento della lista deve puntare alla testa invece che a NULL.
Anche se il concetto di testa piano piano sparisce
cionci è offline   Rispondi citando il messaggio o parte di esso
Old 31-03-2007, 17:33   #8
lucas87
Bannato
 
Iscritto dal: Oct 2006
Messaggi: 170
Questo lo so, ma io chiedo se nella dichiarazione di una lista tra una lista concatenata e una circolare cambia qual cosa e se si cosa?

grazie
lucas87 è offline   Rispondi citando il messaggio o parte di esso
Old 31-03-2007, 17:38   #9
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
No, non cambia assolutamente niente, l'unica differenza è nell'inizializzazione, in cui il campo next dell'ultimo elemento deve puntare alla testa e non a null (come fai nel codice).
cionci è offline   Rispondi citando il messaggio o parte di esso
Old 31-03-2007, 18:56   #10
lucas87
Bannato
 
Iscritto dal: Oct 2006
Messaggi: 170
Potresti indicarmi dove lo faccio puntare a NULL nel codice? NOn lo trovo

grazier
lucas87 è offline   Rispondi citando il messaggio o parte di esso
Old 31-03-2007, 19:07   #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
Codice:
LINK carica(LINK L, int n){
     if (n==0) return NULL;
     else {
          L=malloc(sizeof(ELEMENT));
          printf("inserisci l' elemento nella lista\n");
          scanf("%d",&L->el);
          L->next=carica(L,n-1);
          return L;
     }
}
Quando arrivi all'ultimo elemento ritorni NULL, invece avresti dovuto ritornare l'elemento in testa.
Comunque io per un lista circolare inizializzerei la lista tramite un inserimento in testa.
In questo modo sei sicuro di mantenere sempre la lista consistente...

Inoltre mi sembra di vedere un altro problema, devi fare così nel main:

L = carica(L,n_el);

altrimenti il valore di L non viene modificato e rimane sempre pari a NULL
cionci è offline   Rispondi citando il messaggio o parte di esso
Old 31-03-2007, 19:29   #12
lucas87
Bannato
 
Iscritto dal: Oct 2006
Messaggi: 170
Niente non riesco a farlo andare.
Non è che mi fai creazione inserimento caricamento di una lista circolare tipo quello che ho fatto io ma funzionante?
Se puoi.

Gazrie
lucas87 è offline   Rispondi citando il messaggio o parte di esso
Old 31-03-2007, 21:43   #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
Primo suggerimento: non mescolare mai l'input con gli algoritmi, un input ricorsivo non è bellissimo
Codice:
LINK carica_elemento_in_testa(LINK old, int valore)
{
   LINK head = (LINK)malloc(sizeof(ELEMENT));
   head->el = valore;
   
   if(old == NULL)
      old = head;
   
   head->next = old;

   return head;      
}
Poi ovviamente nel main dovrai inserire un for in cui chiederai in input l'intero e poi lo passerai alla funzione sopra.

Nel main definisci:

LINK head = NULL;

Quindi nel for dopo l'input con scanf richiama la funzione sopra così:

head = carica_elemento_in_testa(head, valore_letto);

Ovviamente tutto non compilato e passibile di sviste
cionci è offline   Rispondi citando il messaggio o parte di esso
Old 01-04-2007, 10:57   #14
lucas87
Bannato
 
Iscritto dal: Oct 2006
Messaggi: 170
In teoria ora va il caricamneto, ma non va la stampa se come consizione metto che il puntatore che si muove L2 deve tornare alla posizione iniziale ed essere = al puntatore che rimane fermo L.
Se uso un for per stampare va,anche se con l'inserimento che mi stai facendo fare tu sembra di caricare uno stak e infatti la stampa la fa diciamo al contrario.
lucas87 è offline   Rispondi citando il messaggio o parte di esso
Old 01-04-2007, 11:09   #15
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
Sì, è chiaro, facendo l'inserimento in testa si carica al contrario, ma non mi sembra che tu abbia vincoli da questo punto di vista, no ? Per la stampa comunque se vuoi mantenere l'ordine di inserimento puoi fare una visita posticipata...

Che ti succede con la ricerca che avevi fatto sopra ? Ti si pianta ?
cionci è offline   Rispondi citando il messaggio o parte di esso
Old 01-04-2007, 11:58   #16
lucas87
Bannato
 
Iscritto dal: Oct 2006
Messaggi: 170
Si ora la ricerca va che è una mervaiglia. grazie.
ti linko anche questo post, magari sai darmi un consiglio

http://www.hwupgrade.it/forum/showth...6#post16578656

grazie
lucas87 è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Corsair Vanguard Air 99 Wireless: non si era mai vista una tastiera gaming così professionale Corsair Vanguard Air 99 Wireless: non si era mai...
Ecovacs DEEBOT T90 PRO OMNI: ora il rullo di lavaggio è ampio Ecovacs DEEBOT T90 PRO OMNI: ora il rullo di lav...
Recensione Samsung Galaxy S26 Ultra: finalmente qualcosa di nuovo Recensione Samsung Galaxy S26 Ultra: finalmente ...
Diablo II Resurrected: il nuovo DLC Reign of the Warlock Diablo II Resurrected: il nuovo DLC Reign of the...
Deep Tech Revolution: così Area Science Park apre i laboratori alle startup Deep Tech Revolution: così Area Science P...
Componenti PC in offerta su Amazon: GPU,...
Ecobonus moto elettriche 2026: fino a 4....
Le nuove offerte Amazon, con aggiornamen...
5 motivi per comprare oggi Motorola Edge...
I produttori di memorie non vogliono inv...
VMware Hosted Private Cloud, il cloud pr...
Le cuffie per giocatori JBL Quantum 910X...
Xiaomi Watch S3 a prezzo dimezzato: 15 g...
Nothing Phone (2a) a poco più di ...
OnePlus prepara due nuovi tablet Android...
ASUS Zenbook supera MacBook Air in tutto...
Amazfit Active 2 a 71,49€ protagonista d...
Tutti gli iPhone avranno display ProMoti...
DLSS 5 irriso sul web, secondo il CEO di...
Scoperta al CERN una particella mai vist...
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: 11:15.


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