Ho ancora un problema sulle duplicazione liste in c.Questa volta ho creato 2 viste e vorrei che la funzione mi compari la somma dei numeri in posizione pari della lista l1 e quelli in posizione dispari della l2 e ritorni 0 se uguali 1 se diversi,ma ho ancora il problema se una finisce prima dell' altre.....
codice:
#include <stdlib.h>
#include <stdio.h>
typedef struct nod {
int data;
struct nod *next;
struct nod *prev;
} node;
node *newnode(void)
{
return (node *)malloc(sizeof(node));
}
/* Dato un intero n>0, costruisce la lista di nodi da 1 ad n */
node *buildlis()
{
int x;
node *lis, *p, *last;
printf("nuovo numero da inserire in lista:\n");
scanf("%d", &x);
if (x==00000)
lis= NULL; /* caso di lista vuota */
else
{
/* inserzione del primo elemento in una lista */
last=newnode();
lis = last;
last->data = x;
last->next = NULL;
printf("nuovo numero da inserire in lista (00000 per terminare):\n");
scanf("%d", &x);
while (x!=00000)
/* Invariante: lis punta alla lista con tutti gli interi finora letti, tranne l'ultimo, e last punta all'ultimo nodo di tale lista */
{
p=newnode();
p->data = x;
p->next = NULL;
last->next = p;
last = p;
printf("nuovo numero da inserire in lista (00000 per terminare):\n");
scanf("%d", &x);
}
}
return(lis);
}
/* Stampa degli elementi di una lista */
void printlis(node *lis)
{
node* tmp;
tmp = lis;
int somma=0;float media=0;int conteggio=0;
while (tmp != NULL) {
printf(">>>> %d\n", tmp->data) && (somma=somma+tmp->data) && (conteggio=conteggio+1) ;
tmp = tmp->next;
}
printf("Somma %d\n",somma);
printf("Conteggio %d \n",conteggio);
media=(somma/conteggio);
printf("Media %f",media);
}
void myFree ( node* top )
{
node* tmp;
tmp = top;
while ( top->next != NULL ) {
tmp = top->next;
free(top);
top = tmp;
}
}
int uguali(node *l1,node *l2)
{
int somma1=0;
int somma2=0;
int pos=1;
if ((l1 == NULL) && (l2 == NULL)) return 0;
else
while ((l1!=NULL) && (l2!=NULL)){
if(pos%2!=0) somma1=somma1+l1->data;
else somma2=somma2+l2->data;
pos++;
l1=l1->next;
l2=l2->next;}
printf("Somma1 e' %d e somma2 %d",somma1,somma2);
if ((l1 == NULL) && (l2 == NULL)) return (somma1+somma2);
else(l1==NULL);{
while (l2!=NULL){
somma2=somma2+l2->data;
l2=l2->next;}}
}
int main()
{
node* head;node* head2;node *dup;
int n;int m=6;
printf ("-----LISTA A-----\n");
head = buildlis ( );
printf ("-----LISTA B-----\n");
head2 = buildlis ( );
printf ("\n-----STAMPA LISTA A-----\n");
int a=3;
printlis(head);
printf ("\n-----STAMPA LISTA B-----\n");
printlis(head2);
printf ("\n-----STAMPA LISTA A MODIFICATA-----\n");
int sommaval=0;
sommaval=uguali(head,head2);
printf ("\nLa somma e' %d\n",sommaval);
if(sommaval>0) printf ("\nUGUALI\n");
else printf ("\nDIVERSE\n");
myFree ( head );
return 0;
}