Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Display, mini PC, periferiche e networking: le novità ASUS al CES 2026
Display, mini PC, periferiche e networking: le novità ASUS al CES 2026
Sono molte le novità che ASUS ha scelto di presentare al CES 2026 di Las Vegas, partendo da una gamma di soluzioni NUC con varie opzioni di processore passando sino agli schermi gaming con tecnologia OLED. Il tutto senza dimenticare le periferiche di input della gamma ROG e le soluzioni legate alla connettività domestica
Le novità ASUS per il 2026 nel settore dei PC desktop
Le novità ASUS per il 2026 nel settore dei PC desktop
Molte le novità anticipate da ASUS per il 2026 al CES di Las Vegas: da schede madri per processori AMD Ryzen top di gamma a chassis e ventole, passando per i kit di raffreddamento all in one integrati sino a una nuova scheda video GeForce RTX 5090. In sottofondo il tema dell'intelligenza artificiale con una workstation molto potente per installazioni non in datacenter
Le novità MSI del 2026 per i videogiocatori
Le novità MSI del 2026 per i videogiocatori
Con le nuove soluzioni della serie MEG, acronimo di MSI Enthusiast Gaming, l'azienda taiwanese vuole proporre per il 2026 una gamma di proposte desktop che si rivolgono direttamente all'utente più appassionato con schede madri, chassis e sistemi di raffreddamento. Non da ultimi troviamo anche gli alimentatori, che abbinano potenza a ricerca della massima sicurezza di funzionamento.
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 07-02-2013, 21:21   #1
sam333
Member
 
Iscritto dal: Jan 2013
Messaggi: 205
[C]Liste non aggiunge al primo elemento

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

struct nodi{

int info;
struct nodi *suc;


};

typedef struct nodi nodo;



nodo *crea_lista(){

 nodo *lista;
system("cls");
lista=NULL;
lista=(nodo*)malloc(sizeof(nodo));
printf("1 Numero:--> ");
scanf("%d",&lista->info);

return lista;

}


nodo *crea_no(nodo* lista,int n){

int i;
for(i=2; i<=n; i++){

    lista->suc=(nodo*)malloc(sizeof(nodo));
    lista=lista->suc;
    printf("%d Numero:--> ",i);
    scanf("%d",&lista->info);


}

lista->suc=NULL;
return lista;

}


void stampa(nodo*lista){

while(lista!=NULL){

    printf("%d   ",lista->info);
    lista=lista->suc;

}
system("Pause");
}



void cerca_nodo(nodo *lista,int ele){



printf("\n\nElemento da trovare:--> ");
scanf("%d",&ele);
while(lista!=NULL && ele!=lista->info ){


    lista=lista->suc;

}

if(lista!=NULL){

    printf("\n\nElemento trovato!");

}
else  printf("\n\nNessun elemento trovato..");
}


nodo *distruggi(nodo *lista){

nodo *tmp;

while(lista!=NULL){

    tmp=lista->suc;
    free(lista);
    lista=tmp;


}

}




void *ordina(nodo*lista){
nodo *tmp,*lista2;

int num;
lista2=lista;
while(lista2->suc!=NULL){

    tmp=lista;
    while(tmp->suc!=NULL){


 if(tmp->info > tmp->suc->info){

    num=tmp->info;
    tmp->info=tmp->suc->info;
    tmp->suc->info=num;
 }
    tmp=tmp->suc;
    }

        lista2=lista2->suc;



}


}



void *aggiungi(nodo *lista){
 nodo *corent,*newnodo=NULL,*prec;
 int elemento;
prec=NULL;
corent=lista;
fflush(stdin);
printf("Elemento da aggiungere:--> ");
scanf("%d",&elemento);

while(corent!=NULL && elemento > corent->info){
 prec=corent;
 corent=corent->suc;
}
if(prec==NULL){
newnodo=(nodo*)malloc(sizeof(nodo));
newnodo->info=corent;
newnodo->suc=lista;
corent=newnodo;

return lista;
}
else{
         newnodo=(nodo*)malloc(sizeof(nodo));
newnodo->info=elemento;
  prec->suc=newnodo;
  newnodo->suc=corent;

}
}





int main(){

int n,ele;
nodo*lista,*lista2;

printf("Quanti elementi vuoi inserire?--> ");
scanf("%d",&n);
lista=crea_lista();
lista2=lista;
lista2=crea_no(lista,n);
stampa(lista);
cerca_nodo(lista,ele);
distruggi(lista);
ordina(lista);
printf("\n\n");
aggiungi(lista);
stampa(lista);
}


ciao a tutti come potete vedere sto cercando di gestire le liste ma non capisco come mai non mi aggiunge il primo elemento...mi spiego....

io inserisco :10-4-3-6
mi riordina :3-4-6-10
poi se inserisco 1 o due non me lo inserisce se invece è un numero che si va a collocare in mezzo o a fine lista allora va tutto bene cosa sbaglio?
sam333 è offline   Rispondi citando il messaggio o parte di esso
Old 07-02-2013, 21:35   #2
M@Rk0
Senior Member
 
L'Avatar di M@Rk0
 
Iscritto dal: May 2008
Città: Torino - Valenza (AL)
Messaggi: 1221
ho bovinamente copiato e incollato il codice e l'ho compilato e dice che c'è un errore di assegnazione nella aggiungi, dove fai newnodo->info=corent; quindi a colpo d'occhio ti sei semplicemente confuso ad assegnare a info il puntatore al nodo seguente anzichè un intero, che suppongo debba essere elemento.
ora provo a correggerlo

edit: inoltre mi risultava che per usare system("cls") e altri system(arg) in windows servisse includere windows.h (suppongo che tu stia usando windows perchè "cls" non è un comando bash di unix), ma non posso controllare perchè non uso windows per programmare

edit2: ho messo elemento in quella linea e ora compila, ma facendolo andare, dopo che mi chiede che numero aggiungere entra in un loop

edit3: (edito mano a mano che trovo cose questionabili) nella aggiungi fai un return ma aggiungi è di tipo void quindi non dovresti ritornare niente. più specificatamente la tua aggiungi è di tipo puntatore a void, quindi si può anche togliere il * da aggiungi. tant'è che ritorni lista ma non fai alcun assegnamento del return della funzione aggiungi

edit4: ok te l'ho aggiustato. hai fatto un po' di confusione, confronta cosa ho cambiato rispetto al tuo (a parte le chiamate system commentate perchè non uso windows), se non capisci cosa hai sbagliato e perchè, chiedi

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

typedef struct nodi
{
	int info;
	struct nodi *suc;
} nodo;

nodo *crea_lista()
{
	nodo *lista;
	//system("cls");
	lista=NULL;
	lista=(nodo*)malloc(sizeof(nodo));
	printf("1 Numero:--> ");
	scanf("%d",&lista->info);
	return lista;
}

nodo *crea_no(nodo* lista,int n)
{
	int i;
	nodo *newnodo, *testa=lista;
	for(i=2; i<=n; i++)
	{
		newnodo=(nodo*)malloc(sizeof(nodo));
		lista->suc=newnodo;
		lista=lista->suc;
		printf("%d Numero:--> ",i);
		scanf("%d",&lista->info);
	}
	lista->suc=NULL;
	return testa;
}


void stampa(nodo*lista)
{
	while(lista!=NULL)
	{
		printf("%d   ",lista->info);
		lista=lista->suc;
	}
	//system("Pause");
}

void cerca_nodo(nodo *lista,int ele)
{
	printf("\n\nElemento da trovare:--> ");
	scanf("%d",&ele);
	while(lista!=NULL && ele!=lista->info )
	{
		lista=lista->suc;
	}
	if(lista!=NULL)
	{
		printf("\n\nElemento trovato!");
	}
	else  printf("\n\nNessun elemento trovato..");
}

nodo *distruggi(nodo *lista)
{
	nodo *tmp;
	while(lista!=NULL)
	{
		tmp=lista->suc;
		free(lista);
		lista=tmp;
	}
}

void ordina(nodo*lista)
{
	nodo *tmp,*lista2;
	int num;
	lista2=lista;
	while(lista2->suc!=NULL)
	{
		tmp=lista;
		while(tmp->suc!=NULL)
		{
			if(tmp->info > tmp->suc->info)
			{
				num=tmp->info;
				tmp->info=tmp->suc->info;
				tmp->suc->info=num;
			}
			tmp=tmp->suc;
		}
		lista2=lista2->suc;
	}
}



nodo *aggiungi(nodo *lista)
{
	nodo *corent,*newnodo=NULL,*prec;
	int elemento;
	prec=NULL;
	corent=lista;
	fflush(stdin);
	printf("Elemento da aggiungere:--> ");
	scanf("%d",&elemento);

	while(corent!=NULL && elemento > corent->info)
	{
		prec=corent;
		corent=corent->suc;
	}
	if(prec==NULL)
	{
		newnodo=(nodo*)malloc(sizeof(nodo));
		newnodo->info=elemento;
		newnodo->suc=lista;
		lista=newnodo;
	}
	else
	{
		newnodo=(nodo*)malloc(sizeof(nodo));
		newnodo->info=elemento;
		prec->suc=newnodo;
		newnodo->suc=corent;
	}
	return (lista);
}


int main()
{
	int n,ele;
	nodo*lista,*lista2;
	printf("Quanti elementi vuoi inserire?--> ");
	scanf("%d",&n);
	lista=crea_lista();
	//lista2=lista;
	lista=crea_no(lista,n);
	stampa(lista);
	cerca_nodo(lista,ele);
	//distruggi(lista);
	ordina(lista);
	printf("\n\n");
	lista=aggiungi(lista);
	stampa(lista);
}

Ultima modifica di M@Rk0 : 07-02-2013 alle 22:17.
M@Rk0 è offline   Rispondi citando il messaggio o parte di esso
Old 08-02-2013, 14:34   #3
sam333
Member
 
Iscritto dal: Jan 2013
Messaggi: 205
Quote:
Originariamente inviato da M@Rk0 Guarda i messaggi
ho bovinamente copiato e incollato il codice e l'ho compilato e dice che c'è un errore di assegnazione nella aggiungi, dove fai newnodo->info=corent; quindi a colpo d'occhio ti sei semplicemente confuso ad assegnare a info il puntatore al nodo seguente anzichè un intero, che suppongo debba essere elemento.
ora provo a correggerlo

edit: inoltre mi risultava che per usare system("cls") e altri system(arg) in windows servisse includere windows.h (suppongo che tu stia usando windows perchè "cls" non è un comando bash di unix), ma non posso controllare perchè non uso windows per programmare

edit2: ho messo elemento in quella linea e ora compila, ma facendolo andare, dopo che mi chiede che numero aggiungere entra in un loop

edit3: (edito mano a mano che trovo cose questionabili) nella aggiungi fai un return ma aggiungi è di tipo void quindi non dovresti ritornare niente. più specificatamente la tua aggiungi è di tipo puntatore a void, quindi si può anche togliere il * da aggiungi. tant'è che ritorni lista ma non fai alcun assegnamento del return della funzione aggiungi

edit4: ok te l'ho aggiustato. hai fatto un po' di confusione, confronta cosa ho cambiato rispetto al tuo (a parte le chiamate system commentate perchè non uso windows), se non capisci cosa hai sbagliato e perchè, chiedi

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

typedef struct nodi
{
	int info;
	struct nodi *suc;
} nodo;

nodo *crea_lista()
{
	nodo *lista;
	//system("cls");
	lista=NULL;
	lista=(nodo*)malloc(sizeof(nodo));
	printf("1 Numero:--> ");
	scanf("%d",&lista->info);
	return lista;
}

nodo *crea_no(nodo* lista,int n)
{
	int i;
	nodo *newnodo, *testa=lista;
	for(i=2; i<=n; i++)
	{
		newnodo=(nodo*)malloc(sizeof(nodo));
		lista->suc=newnodo;
		lista=lista->suc;
		printf("%d Numero:--> ",i);
		scanf("%d",&lista->info);
	}
	lista->suc=NULL;
	return testa;
}


void stampa(nodo*lista)
{
	while(lista!=NULL)
	{
		printf("%d   ",lista->info);
		lista=lista->suc;
	}
	//system("Pause");
}

void cerca_nodo(nodo *lista,int ele)
{
	printf("\n\nElemento da trovare:--> ");
	scanf("%d",&ele);
	while(lista!=NULL && ele!=lista->info )
	{
		lista=lista->suc;
	}
	if(lista!=NULL)
	{
		printf("\n\nElemento trovato!");
	}
	else  printf("\n\nNessun elemento trovato..");
}

nodo *distruggi(nodo *lista)
{
	nodo *tmp;
	while(lista!=NULL)
	{
		tmp=lista->suc;
		free(lista);
		lista=tmp;
	}
}

void ordina(nodo*lista)
{
	nodo *tmp,*lista2;
	int num;
	lista2=lista;
	while(lista2->suc!=NULL)
	{
		tmp=lista;
		while(tmp->suc!=NULL)
		{
			if(tmp->info > tmp->suc->info)
			{
				num=tmp->info;
				tmp->info=tmp->suc->info;
				tmp->suc->info=num;
			}
			tmp=tmp->suc;
		}
		lista2=lista2->suc;
	}
}



nodo *aggiungi(nodo *lista)
{
	nodo *corent,*newnodo=NULL,*prec;
	int elemento;
	prec=NULL;
	corent=lista;
	fflush(stdin);
	printf("Elemento da aggiungere:--> ");
	scanf("%d",&elemento);

	while(corent!=NULL && elemento > corent->info)
	{
		prec=corent;
		corent=corent->suc;
	}
	if(prec==NULL)
	{
		newnodo=(nodo*)malloc(sizeof(nodo));
		newnodo->info=elemento;
		newnodo->suc=lista;
		lista=newnodo;
	}
	else
	{
		newnodo=(nodo*)malloc(sizeof(nodo));
		newnodo->info=elemento;
		prec->suc=newnodo;
		newnodo->suc=corent;
	}
	return (lista);
}


int main()
{
	int n,ele;
	nodo*lista,*lista2;
	printf("Quanti elementi vuoi inserire?--> ");
	scanf("%d",&n);
	lista=crea_lista();
	//lista2=lista;
	lista=crea_no(lista,n);
	stampa(lista);
	cerca_nodo(lista,ele);
	//distruggi(lista);
	ordina(lista);
	printf("\n\n");
	lista=aggiungi(lista);
	stampa(lista);
}

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

struct nodi{

int info;
struct nodi *suc;


};

typedef struct nodi nodo;

///CREO LA LISTA
nodo *crea_lista(){

nodo *lista;

lista==NULL;

lista=(nodo*)malloc(sizeof(nodo));
  printf("1 Numero:--> ");
scanf("%d",&lista->info);
return lista;
}

///CREO I NODI SUCCESSIVI
nodo *crea_nod(nodo *lista,int n){

nodo *iniz=lista;
nodo *newnodo;
int i;

   iniz=lista;
for(i=2; i<=n; i++){

   newnodo=(nodo*)malloc(sizeof(nodo));


   lista->suc=newnodo;

   lista=lista->suc;
  printf("%d Numero:--> ",i);
scanf("%d",&lista->info);

}
return iniz;
}


///STAMPO LA LISTA INTERA


void stampa(nodo *lista){


while(lista!=NULL){

    printf("%d   ",lista->info);
    lista=lista->suc;

}


}


///ORDINO LA LISTA


void  ordina(nodo *lista){

nodo *lista2,*tmp;
int num;
lista2=lista;
while(lista2->suc!=NULL){

    tmp=lista;

    while(tmp->suc!=NULL){

        if(tmp->info > tmp->suc->info){

        num=tmp->info;
        tmp->info=tmp->suc->info;
        tmp->suc->info=num;


        }
        tmp=tmp->suc;

}
lista2=lista2->suc;
}
}



void cerca(nodo *lista){

int ele;
printf("Quale elemento vuoi cercare?-->");
scanf("%d",&ele);
while(lista!=NULL && ele!=lista->info){

    lista=lista->suc;


}
if(lista==NULL){

    printf("\n\nElemento non trovato...");

}
else printf("\n\nTrovato!");
}





///AGGIUNGO ELEMENTO


nodo *agg(nodo*lista){


nodo *corent=lista;
nodo *prec=NULL,*newnod=NULL;
int ele;

printf("\n\nInserire elemento da aggiungere:--> ");
scanf("%d",&ele);
while(corent!=NULL && ele > corent->info ){
    prec=corent;
    corent=corent->suc;

}

if(prec==NULL){
    newnod=(nodo*)malloc(sizeof(nodo));
    newnod->info=ele;
    newnod->suc=lista;
    lista=newnod;

}
else{
    newnod=(nodo*)malloc(sizeof(nodo));
newnod->info=ele;
prec->suc=newnod;
newnod->suc=corent;
}
return lista;
}



///CANCELLO ELEMENTO


nodo *canc(nodo *lista){

int ele;
nodo *corent=lista,*prec=NULL;
printf("Quale elemento vuoi eliminare?");
stampa(lista);
printf("\n\nScelta:--> ");
scanf("%d",&ele);
while(corent!=NULL && ele!=corent->info){

    prec=corent;
    corent=corent->suc;
}
if(ele==corent->info){


    if(prec==NULL){

       lista=corent->suc;
    }
    else
    {
        prec->suc=corent->suc;


    }
            free(corent);
}
return lista;
}


///DISTRUGGO LISTA

nodo *distruggi(nodo *lista)
{
	nodo *tmp;
	while(lista!=NULL)
	{
		tmp=lista->suc;
		free(lista);
		lista=tmp;
	}
}
int main()
{
    int num;
    nodo *lista;

    printf("\t\t\t***LISTA***\n\n\n\n\nQuanti elementi vuoi inserire?--> ");
    scanf("%d",&num);
lista=crea_lista();
 lista=crea_nod(lista,num);
 stampa(lista);
 system("pause");
 ordina(lista);
 stampa(lista);
  system("pause");
  cerca(lista);
lista=agg(lista);
 stampa(lista);
  system("pause");
  lista=canc(lista);
  stampa(lista);
  system("pause");
  lista=distruggi(lista);
    return 0;
}

ho riscritto il codice seguendo i tuoi consigli ...ora va bene così?
ma di preciso il loop cosa sarebbe?come lo evito?grazie ancora per l'aiuto
sam333 è offline   Rispondi citando il messaggio o parte di esso
Old 08-02-2013, 17:56   #4
M@Rk0
Senior Member
 
L'Avatar di M@Rk0
 
Iscritto dal: May 2008
Città: Torino - Valenza (AL)
Messaggi: 1221
si ora funziona, metti solo un po' a posto le stampe perchè di primo impatto sembrava che la lista fosse sbagliata, invece la stampava due volte di fila (ad esempio prima dell'ordinamento e dopo, io pensavo già a dei puntatori andati a caso ).

un loop è quando il programma si mette a fare qualcosa e non ne esce più se non lo interrompe un agente esterno (es: tu). in questo caso c'era qualcosa di sbagliato con i puntatori nella aggiungi e nel main, perchè cercavi di dare a lista2 la lista con un elemento aggiunto a lista, poi le successive funzioni le facevi comunque fare su lista, e lista2 non la usavi mai. non riesco a ricostruire il comportamento che fa diventare la lista un cerchio (l'ultimo nodo punta al primo) ma come output a schermo avevo (se aggiungevo "1"): 1 890852 1 890852 1 890852 1 890852 1 890852 1 890852... (890852 l'ho inventato sul momento, è l'indirizzo di corent (che tu assegnavi a newnodo->info al posto di elemento)).

insomma un casino
M@Rk0 è offline   Rispondi citando il messaggio o parte di esso
Old 08-02-2013, 19:32   #5
sam333
Member
 
Iscritto dal: Jan 2013
Messaggi: 205
grazie mille!ottima spiegazione
sam333 è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Display, mini PC, periferiche e networking: le novità ASUS al CES 2026 Display, mini PC, periferiche e networking: le n...
Le novità ASUS per il 2026 nel settore dei PC desktop Le novità ASUS per il 2026 nel settore de...
Le novità MSI del 2026 per i videogiocatori Le novità MSI del 2026 per i videogiocato...
I nuovi schermi QD-OLED di quinta generazione di MSI, per i gamers I nuovi schermi QD-OLED di quinta generazione di...
Recensione vivo X300 Pro: è ancora lui il re della fotografia mobile, peccato per la batteria Recensione vivo X300 Pro: è ancora lui il...
Fibra di carbonio, lega di magnesio e 8....
Inaugurato il Padiglione Italia al CES 2...
AGON PRO AG276QSG2: NVIDIA G-Sync Pulsar...
MSI mostra la scheda madre consumer con ...
MSI rinnova l'intera offerta notebook al...
Laifen Wave Pro: debutta al CES lo spazz...
XGIMI Titan Noir Max: al CES il videopro...
Atlas di Boston Dynamics: il robot umano...
TV da 130 pollici ed elettrodomestici, p...
I giochi classici cambiano volto con RTX...
OpenAI testa la pubblicità in Cha...
Plaud riscrive il modo di prendere appun...
Narwal presenta a Las Vegas la nuova gam...
1000W solo per la scheda video: la GeFor...
NVIDIA espande GeForce NOW: nuove app Li...
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: 06:04.


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