Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Nutanix: innovazione, semplicità e IA al centro della strategia hybrid multicloud
Nutanix: innovazione, semplicità e IA al centro della strategia hybrid multicloud
Al Museo Alfa Romeo di Arese, Nutanix ha riunito clienti, partner ed esperti per .Next On Tour Italia e per mostrare come l’infrastruttura hybrid multicloud possa diventare il fondamento dell’innovazione, con una piattaforma capace di unificare applicazioni tradizionali, moderne architetture cloud-native e nuovi scenari basati sull’intelligenza artificiale
Lenovo LOQ 15i Gen 10 (15IRX10) alla prova: il notebook gaming 'budget' che non ti aspetti
Lenovo LOQ 15i Gen 10 (15IRX10) alla prova: il notebook gaming 'budget' che non ti aspetti
Il Lenovo LOQ 15i Gen 10 (15IRX10) offre prestazioni convincenti grazie al Core i7-13650HX e alla RTX 5060 Laptop a 100W, mantenendo un prezzo competitivo tra 1100 e 1300 euro. Costruzione solida, buon display e ampia espandibilità lo rendono una scelta equilibrata per chi cerca un notebook gaming accessibile ma moderno.
Due mesi di Battlefield 6: dalla campagna al battle royale, è l'FPS che stavamo aspettando
Due mesi di Battlefield 6: dalla campagna al battle royale, è l'FPS che stavamo aspettando
Abbiamo giocato a lungo a Battlefield 6, abbiamo provato tutte le modalità multiplayer, Redsec, e le numerose personalizzazioni. In sintesi, ci siamo concentrati su ogni aspetto del titolo per comprendere al meglio uno degli FPS più ambiziosi della storia dei videogiochi e, dopo quasi due mesi, abbiamo tirato le somme. In questo articolo, condividiamo con voi tutto ciò che è Battlefield 6, un gioco che, a nostro avviso, rappresenta esattamente ciò che questo genere attendeva da tempo
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 12-06-2009, 20:14   #1
Gr1ph00n
Member
 
Iscritto dal: Oct 2006
Messaggi: 67
[C] problema stringhe in liste

Salve a tutti, posto in questa sezionepoichè stò avendo alcuni problemi con un'implementazione, stavo cercando di capire come utilizzare le liste collegate e mi era parso ideale implementare una rubrica. Non ci ho messo molto a realizzarne una semplice, fatto stà che ho un problema con la visualizzazione dei vari campi. Mi spiego meglio, andando a stampare i valori memorizzati con la printf, oltre ai valori che io ho messo, me ne escono anche altri che sono percorsi di file e cartelle, variabili di windows....

Eccovi il mio codice:

Codice:

#include <stdio.h>
#include <stdlib.h>
#include <string.h>

#define MAX_CHAR 30

typedef int BOOL;

#define FALSE 0
#define TRUE !FALSE



typedef struct _rubrica
{
	int id;
	char cognome[MAX_CHAR];
	char nome[MAX_CHAR];
	char numero[MAX_CHAR];
	struct _rubrica *prev;
	struct _rubrica *next;
} rubrica;

typedef struct _lista
{
	rubrica *primo;
	rubrica *ultimo;
} lista;

int menu();
void aggiungi();
void rimuovi();
void visualizza();
void aggiungi_dopo(rubrica *r1, rubrica *r2);
void raccogli_dati(rubrica *r);
rubrica *ottieni_ultimo();
void trim(char *s1);
void aggiungi_inizio(rubrica *r);
void aggiungi_prima(rubrica *r1, rubrica *r2);
void stampa_nodo(rubrica *r);
rubrica *cerca(const int id);
void rimuovi_nodo(rubrica *r);

int rubriche_totali;

lista *list = NULL;

int main (void)
{
	
	void (*f[2])(void);
	int scelta;
	list = malloc(sizeof(lista));
	if (list != NULL)
	{
		list->primo = NULL;
		list->ultimo = NULL;
	}
	
	f[0] = aggiungi;
	f[1] = rimuovi;
	f[2] = visualizza;
	
	printf("RUBRICA 0.1\n");
	scelta = menu();
	while (scelta)
	{
		if (scelta > 3)
		{
			scelta = menu();
			continue;
		}
		f[scelta - 1]();
		scelta = menu();
	}
	system("PAUSE");
	return 0;
}

int menu ()
{
	int ret;
	printf("SELEZIONARE OPZIONE:\n1. Aggiungi\n2. Cancella\n3. Visualizza tutto\n0.Esci\n=> ");
	scanf("%d", &ret);
	printf("\n");
	return ret;
}

rubrica *ottieni_ultimo()
{
	return list->ultimo;
}

void trim(char *s1)
{
    while (TRUE)
    {
        if (*s1 == '\n')
        {   
            *s1 = '\0';
            break;
        }
        s1++;
    }
}

void raccogli_dati(rubrica *r)
{
	char cognome[MAX_CHAR];
	char nome[MAX_CHAR];
	char numero[MAX_CHAR];
	printf("inserire cognome:\n");
	fflush(stdin);
	fgets(cognome, sizeof(cognome), stdin); 
	trim(cognome);
	printf("inserire nome:\n");
	fflush(stdin);
	fgets(nome, sizeof(nome), stdin); 
	trim(nome);
	printf("inserire numero:\n");
	fflush(stdin);
	fgets(numero, sizeof(numero), stdin); 
	trim(numero);
	r->id = rubriche_totali;
	strncpy(r->cognome, cognome, strlen(cognome));
	strncpy(r->nome, nome, strlen(nome));
	strncpy(r->numero, numero, strlen(numero));
	r->prev = NULL;
	r->next = NULL;
	rubriche_totali++;
}




void aggiungi()
{
	rubrica *curr;
	rubrica *r1;
	r1 = malloc(sizeof(rubrica));
	if (r1 != NULL)
	{
		raccogli_dati(r1);
		curr = ottieni_ultimo();
		if (curr)
		{
			aggiungi_dopo(curr, r1);
		}
		else
		{
			aggiungi_inizio(r1);
		}
	}
	printf("aggiunto con id %d\n", rubriche_totali - 1);
}

void aggiungi_inizio(rubrica *r)
{
	if (list->primo)
	{
		aggiungi_prima(list->primo, r);
	}
	else
	{
		list->primo = r;
		list->ultimo = r;
		r->prev = NULL;
		r->next = NULL;
	}
}

void aggiungi_prima(rubrica *r1, rubrica *r2)
{
	r2->prev = r1->prev;
	r2->next = r1;
	if (r1->prev)
	{
		r2->prev->next = r2;
	}
	else
	{
		list->primo = r2;
	}
}

void aggiungi_dopo(rubrica *r1, rubrica *r2)
{
	r2->next = r1->next;
	r1->next = r2;
	r2->prev = r1;
	if (r2->next)
	{
		r2->next->prev = r2;
	}
	else
	{
		list->ultimo = r2;
	}
}
	
rubrica *cerca(const int id)
{
	rubrica *r1;
	r1 = ottieni_ultimo();
	int index;
	for (index = 0; index < rubriche_totali; index++)
	{
		if (r1->id == id)
		{
			return r1;
		}
		else
		{
			r1 = r1->prev;
		}
	}
	return NULL;
}

void rimuovi() 
{
	int id;
	rubrica *r1;
	printf("Inserisci l'id della rubrica da rimuovere: ");
	fflush(stdin);
	scanf("%d", &id);
	r1 = cerca(id);
	if (r1 != NULL)
	{
		rimuovi_nodo(r1);
	}
	else
	{
		printf("valore inesistente\n");
	}
}

void rimuovi_nodo(rubrica *r)
{
	if (r->prev)
	{
		r->prev->next = r->next;
	}
	else
	{
		list->primo = r->next;
	}
	
	if (r->next)
	{
                r->next->id -= 1;
		r->next->prev = r->prev;
	}
	else
	{
		list->ultimo = r->prev;
	}
	free(r);
}



void visualizza() 
{
	int id;
	rubrica *r1;
	printf("Inserisci l'id della rubrica da visualizzare: ");
	fflush(stdin);
	scanf("%d", &id);
	r1 = cerca(id);
	if (r1 != NULL)
	{
		stampa_nodo(r1);
	}
	else
	{
		printf("valore inesistente\n");
	}
}

void stampa_nodo(rubrica *r)
{
	printf("cognome=%s\nnome=%s\nnumero=%s\n", r->cognome, r->nome, r->numero);
}
Potreste aiutarmi per favore a capire dove stà l'errore ? Grazie in anticipo

Ultima modifica di Gr1ph00n : 12-06-2009 alle 20:32.
Gr1ph00n è offline   Rispondi citando il messaggio o parte di esso
Old 12-06-2009, 22:58   #2
BrutPitt
Senior Member
 
L'Avatar di BrutPitt
 
Iscritto dal: Mar 2009
Città: Bologna
Messaggi: 1174
Ho dato una scorsa veloce... ma permettimi una domanda: perche' usi "strncpy" con la lunghezza della stringa sorgente?

Codice:
	strncpy(r->cognome, cognome, strlen(cognome));
	strncpy(r->nome, nome, strlen(nome));
	strncpy(r->numero, numero, strlen(numero));
Basterebbe una semplice "strcpy".

Con "strncpy" se vuoi copiare anche il carattere nullo devi aggiungere un +1 alla lunghezza... dato che non e' aggiunto implicitamente.

Come hai fatto tu non "termini" la stringa... ed e' forse questo il motivo dei caratteri non desiderati.

Ultima modifica di BrutPitt : 12-06-2009 alle 23:10. Motivo: maggiore chiarezza
BrutPitt è offline   Rispondi citando il messaggio o parte di esso
Old 12-06-2009, 23:14   #3
Gr1ph00n
Member
 
Iscritto dal: Oct 2006
Messaggi: 67
Si, hai ragione, era quello l'errore, o meglio dovevo usare la sizeof al posto della strlen per non avere problemi, comunque ora ho risolto. Grazie per la risposta
Gr1ph00n è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Nutanix: innovazione, semplicità e IA al centro della strategia hybrid multicloud Nutanix: innovazione, semplicità e IA al ...
Lenovo LOQ 15i Gen 10 (15IRX10) alla prova: il notebook gaming 'budget' che non ti aspetti Lenovo LOQ 15i Gen 10 (15IRX10) alla prova: il n...
Due mesi di Battlefield 6: dalla campagna al battle royale, è l'FPS che stavamo aspettando Due mesi di Battlefield 6: dalla campagna al bat...
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 ...
Il telescopio spaziale James Webb ha ril...
ESA: budget di 22,32 miliardi di euro pe...
Il rover Yutu-2 della missione cinese Ch...
Le pubblicità del frigorifero man...
Perso il segnale della sonda spaziale NA...
Una Xiaomi SU7 ha finito il suo parchegg...
Decine di associazioni contro i data cen...
Dongfeng batte Toyota e BYD: il suo moto...
Oltre NVIDIA: i server di Red Hat AI acc...
Grok diventa navigatore Tesla: Musk prom...
Broadcom/VMware e Siemens continuano a l...
NIO lancia il brand Firefly anche in Gre...
Trump annuncia una legge nazionale sull'...
Intel Arc B770: la scheda appare in un d...
Le Big dell'AI e Linux Foundation insiem...
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: 04:00.


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