Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Roborock Qrevo Curv 2 Flow: ora lava con un rullo
Roborock Qrevo Curv 2 Flow: ora lava con un rullo
Qrevo Curv 2 Flow è l'ultima novità di casa Roborock per la pulizia di casa: un robot completo, forte di un sistema di lavaggio dei pavimenti basato su rullo che si estende a seguire il profilo delle pareti abbinato ad un potente motore di aspirazione con doppia spazzola laterale
Alpine A290 alla prova: un'auto bella che ti fa innamorare, con qualche limite
Alpine A290 alla prova: un'auto bella che ti fa innamorare, con qualche limite
Abbiamo guidato per diversi giorni la Alpine A290, la prima elettrica del nuovo corso della marca. Non è solo una Renault 5 sotto steroidi, ha una sua identità e vuole farsi guidare
Recensione HONOR Magic 8 Lite: lo smartphone indistruttibile e instancabile
Recensione HONOR Magic 8 Lite: lo smartphone indistruttibile e instancabile
Abbiamo provato a fondo il nuovo Magic 8 Lite di HONOR, e per farlo siamo volati fino a Marrakech , dove abbiamo testato la resistenza di questo smartphone in ogni condizione possibile ed immaginabile. Il risultato? Uno smartphone praticamente indistruttibile e con un'autonomia davvero ottima. Ma c'è molto altro da sapere su Magic 8 Lite, ve lo raccontiamo in questa recensione completa.
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 23-10-2005, 21:14   #1
-Yara-
Senior Member
 
L'Avatar di -Yara-
 
Iscritto dal: Nov 2003
Città: Pordenone - Tarvisio
Messaggi: 2451
[C]Esercizio con Liste

Salve a tutti...
Devo fare un esercizio con le liste che consiste nel cancellare tutti i numeri pari della lista.
In pratica se ho una lista di questo genere:
6 3 2 1
Deve risultare:
3 1
Il secondo consiste nel, date due liste, vedere se un elemento della lista 1 appartiene alla lista 2.
Chi mi puo' aiutare?
Primo: (nn ho proprio idea di dove partire per cancellare un elemento)

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

using namespace std;

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

nodo* Crea_lista();
void Visualizza_lista(nodo*);
void Elimina(nodo*);

int main()
{
	nodo* lista=NULL; //creo la lista
    lista=Crea_lista();
    Visualizza_lista(lista);
	Elimina(lista);
	Visualizza_lista(lista);
	fflush(stdin);
	getchar();
	return 0;
}

nodo* Crea_lista()
{
	nodo *p,*punt;
	int i,n;
	printf("\nNumero elementi lista: ");
	scanf("%d",&n);
	if(n==0)
	{
		p=NULL;
        
	}
    else
    {
        //inserimento del primo valore
        p=(nodo*)malloc(sizeof(nodo));
        printf("\nInserisci il primo valore");
        scanf("%d",&p->info);
        punt=p;
    }
    for(i=2;i<=n;i++)
    {
        punt->next=(nodo*)malloc(sizeof(nodo));
        punt=punt->next; //scorri
        printf("\nInserisci il %d elemento: ",i);
        scanf("%d",&punt->info);
    }
    punt->next=NULL; 
	return p;
}

void Visualizza_lista(nodo* lista)
{
    printf(" Lista---> ");
	while(lista!=NULL)
	{
        printf("%d",lista->info);
		printf(" ---> ");
		lista=lista->next;
	}
    printf("NULL\n\n");
    getchar();
}

void Elimina(nodo* lista)
{
	nodo* scorri=lista;
    printf("LOL");
    while(scorri!=NULL)
	{
		if(scorri->info%2==0)
		{
			printf("Trovato elemento pari, eliminazione in corso");
			scorri=scorri->next;
			free(scorri);
			lista->next=scorri->next; 
		}
		scorri=scorri->next;
	}
}


L'altro l'ho risolto cosi' (metto solo la funzione che confronta)

Codice:
int Confronta(nodo* lista,nodo* lista2)
{
	nodo* scorri1;
	nodo* scorri2;
	scorri1=lista;
	scorri2=lista2;
	while(scorri1!=NULL)
	{
        while(scorri2!=NULL)
        {
        	if(scorri2->info==scorri1->info)
                return scorri1->info;
            scorri2=scorri2->next;
        }
        scorri1=scorri1->next;
	}
return -1;
}


Grazie a chi mi vorrà aiutare
__________________
Me? The Chosen One? They chose me, and i didn't even graduate from fuckin' high school
Wind FTTE Vula 100/20 - Stats
Retelit / Valcanale 20Mbit/2Mbit // Wind 100/20+Wind4G con EdgerouterX
-Yara- è offline   Rispondi citando il messaggio o parte di esso
Old 24-10-2005, 12:18   #2
-Yara-
Senior Member
 
L'Avatar di -Yara-
 
Iscritto dal: Nov 2003
Città: Pordenone - Tarvisio
Messaggi: 2451
up
__________________
Me? The Chosen One? They chose me, and i didn't even graduate from fuckin' high school
Wind FTTE Vula 100/20 - Stats
Retelit / Valcanale 20Mbit/2Mbit // Wind 100/20+Wind4G con EdgerouterX
-Yara- è offline   Rispondi citando il messaggio o parte di esso
Old 24-10-2005, 20:06   #3
Qu@ker
Member
 
Iscritto dal: Apr 2004
Messaggi: 130
Ma gli esercizi non dovresti farteli da solo?
Codice:
#include <stdio.h>
#include <stdlib.h>

typedef struct nodo {
	int info;
	struct nodo* next;
} nodo;

nodo* creaLista()
{
	nodo *root = NULL, *corrente;
	int i, n;
	fputs("\nNumero elementi lista: ", stdout);
	fflush(stdout);
	scanf("%d", &n);
	if (n > 0) {
		corrente = root = malloc(sizeof(nodo));
		fputs("\nInserisci il 1 elemento: ", stdout);
		fflush(stdout);
		scanf("%d", &corrente->info);
    		for(i = 1; i < n; i++) {
    			corrente->next = malloc(sizeof(nodo));
    			corrente = corrente->next;
    			printf("\nInserisci il %d elemento: ", i+1);
			fflush(stdout);
    			scanf("%d", &corrente->info);
    		}
    		corrente->next = NULL; 
    	}
	return root;
}

void visualizzaLista(nodo* lista)
{
	fputs("Lista: ", stdout);
	for (; lista; lista = lista->next)
        	printf("(%d)-->", lista->info);
	puts("(NULL)\n");
}

void eliminaNodiPari(nodo** lista)
{
	nodo *corrente, *precedente;
	while ((*lista)->info % 2 == 0) {
		nodo *tmp = *lista;
		*lista = (*lista)->next;	
		free(tmp);
	}
	precedente = *lista;
	corrente = precedente->next;
	while (corrente) {
		if (corrente->info % 2 == 0) {
			nodo *tmp = corrente;
			precedente->next = corrente->next;
			corrente = corrente->next;
			free(tmp);
		} else {
			precedente = corrente;
			corrente = corrente->next;
		}
	}
}

int main(void)
{
	nodo *lista = creaLista();
	visualizzaLista(lista);
	eliminaNodiPari(&lista);
	visualizzaLista(lista);

	return 0;
}
Ma il tag spoiler non funziona con tag annidati?

Ultima modifica di Qu@ker : 24-10-2005 alle 20:09.
Qu@ker è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Roborock Qrevo Curv 2 Flow: ora lava con un rullo Roborock Qrevo Curv 2 Flow: ora lava con un rull...
Alpine A290 alla prova: un'auto bella che ti fa innamorare, con qualche limite Alpine A290 alla prova: un'auto bella che ti fa ...
Recensione HONOR Magic 8 Lite: lo smartphone indistruttibile e instancabile Recensione HONOR Magic 8 Lite: lo smartphone ind...
Sony WF-1000X M6: le cuffie in-ear di riferimento migliorano ancora Sony WF-1000X M6: le cuffie in-ear di riferiment...
Snowflake porta l'IA dove sono i dati, anche grazie a un accordo con OpenAI Snowflake porta l'IA dove sono i dati, anche gra...
AMD Radeon RX 9060 XT: staccato (di molt...
WhatsApp introduce la condivisione della...
iPad con chip A16 a 339€: l'11'' con 128...
OpenClaw spaventa le aziende: perch&eacu...
Samsung T7 2TB crolla su Amazon: SSD por...
Tutte le JBL a prezzi da non perdere su ...
PS6 e RDNA 5: la GPU sarà 'quasi ...
Meta cambia rotta sul metaverso: Horizon...
Zeekr debutta in Italia con Jameel Motor...
Robotaxi sotto controllo remoto: Waymo a...
Ubisoft continua i tagli: 40 licenziamen...
PromptSpy: il primo malware Android che ...
Navigare all'estero con costi accessibil...
Boom del fotovoltaico in Africa: +54% in...
Cisco mette l'IA agentica al centro con ...
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: 13:31.


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