Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Nioh 3: souls-like punitivo e Action RPG
Nioh 3: souls-like punitivo e Action RPG
Nioh 3 aggiorna la formula Team NINJA con aree esplorabili più grandi, due stili di combattimento intercambiabili al volo (Samurai e Ninja) e un sistema di progressione pieno di attività, basi nemiche e sfide legate al Crogiolo. La recensione entra nel dettaglio su combattimento, build, progressione e requisiti PC
Test in super anteprima di Navimow i220 LiDAR: il robot tagliaerba per tutti
Test in super anteprima di Navimow i220 LiDAR: il robot tagliaerba per tutti
La facilità di installazione e la completa automazione di tutte le fasi di utilizzo, rendono questo prodotto l'ideale per molti clienti. Ecco com'è andata la nostra prova in anteprima
Dark Perk Ergo e Sym provati tra wireless, software via browser e peso ridotto
Dark Perk Ergo e Sym provati tra wireless, software via browser e peso ridotto
be quiet! debutta nel settore mouse da gaming con Dark Perk Ergo e Dark Perk Sym: due modelli gemelli per specifiche, con polling rate di 8.000 Hz anche in wireless, sensore PixArt PAW3950 da 32.000 DPI e autonomia dichiarata fino a 110 ore. Nel test, a 8.000 Hz si arriva a circa 30 ore reali, con ricarica completa in un'ora e mezza
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 18-05-2011, 22:21   #1
Krat0s
Member
 
Iscritto dal: Jun 2008
Messaggi: 109
[C] Problema con le liste

Ciao a tutti....mi hanno introdotto ieri le liste all'università e ho provato a fare un programmino. Praticamente inserisco il numero di dipendenti dell'azienda, i loro dati (nome e data di assunzione), inserisco un anno da ricercare e mi restituisce i nomi dei dipendenti assunti in quell'anno. Solamente che se io lo faccio partire in modalità debug mi funziona, altrimenti no. Uso Dev C++ su win Xp.

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

struct data {int giorno,mese,anno;};
typedef struct data Data;

struct dipendente { char nome[20];
                    Data datassunzione;
                    };
typedef struct dipendente dip;

struct El { dip info;
            struct El *next;
            };
typedef struct El elemento;
typedef elemento *Listadidipendenti;

struct Punt { elemento *puntatore;
              struct Punt *next;};
typedef struct Punt puntavalore;
typedef puntavalore *Listadipuntatori;

void Inizializza(Listadidipendenti *lista);
void Inizializza2(Listadipuntatori *lispunt);
void Inseriscidati(Listadidipendenti *lista,int numero);
void Ricerca(Listadidipendenti lista,Listadipuntatori *lispunt, int anno);
void Scrivilista(Listadipuntatori lispunt);

main()
{
      int numerodip,anno;
      Listadidipendenti lista;
      Listadipuntatori listapunt;
      Inizializza(&lista);
      Inizializza2(&listapunt);
      printf("Inserire il numero di dipendenti: ");
      scanf("%d",&numerodip);
      Inseriscidati(&lista,numerodip);
      printf("\n\nInserire l'anno da cercare: ");
      scanf("%d",&anno);
      Ricerca(lista,&listapunt,anno);
      printf("\n\nLISTA DEI DIPENDENTI ASSUNTI NELL'ANNO %d:\n",anno);
      Scrivilista(listapunt);
      system("PAUSE");
      
      
}

void Inizializza(Listadidipendenti *lista)
{
     *lista = NULL;
}
void Inizializza2(Listadipuntatori *lispunt)
{
     *lispunt = NULL;
}
void Inseriscidati(Listadidipendenti *lista,int numero)
{
     int i,j;
     char c;
     Listadidipendenti aux;
     for (i=1;i<=numero;i++) {
                               aux=malloc(sizeof(dip));
                               printf("\nInserire il nome del dipendente numero %d: ",i);
                               for (j=0;j<20;j++)  aux->info.nome[j] = '0';
                               j=1;
                               scanf("%c",&c);
                               do { scanf("%c",&c);
                                    if (c != '\n') aux->info.nome[j] = c;
                                    j++;
                                    }
                               while (c!='\n');
                               printf("Inserire la data di assunzione: ");
                               scanf("%d %d %d",&aux->info.datassunzione.giorno,&aux->info.datassunzione.mese,&aux->info.datassunzione.anno);
                               aux->next = *lista;
                               *lista = aux;
                               }
}
void Ricerca(Listadidipendenti lista,Listadipuntatori *lispunt, int anno)
{
     Listadipuntatori aux;
     while (lista!=NULL) {
                          if (lista->info.datassunzione.anno == anno) {
                                                                       aux = malloc(sizeof(puntavalore));
                                                                       aux->puntatore = lista; aux->next=*lispunt;
                                                                       *lispunt = aux;
                                                                      }
                          lista = lista->next;
                         }
}
void Scrivilista(Listadipuntatori lispunt)
{
     int i=0;
     while (lispunt != NULL) {
                              i=0;
                              while (lispunt->puntatore->info.nome[i]!='0') { putchar(lispunt->puntatore->info.nome[i]);
                                                                   i++;
                                                                 }
                              printf("\n");
                              lispunt= lispunt->next;
                             }
 }
Secondo le intenzioni utilizzo due liste, una per i dipendenti e l'altra con gli indirizzi che puntano agli elementi cercati....se qualcuno può dargli un'occhiata...
Krat0s è offline   Rispondi citando il messaggio o parte di esso
Old 19-05-2011, 01:14   #2
Gimli[2BV!2B]
Senior Member
 
L'Avatar di Gimli[2BV!2B]
 
Iscritto dal: Feb 2006
Città: Parma
Messaggi: 3010
Varie osservazioni:
  • ti sei impegnato molto ad aggrovigliare i puntatori, in primo luogo un typedef di questo tipo lo eviterei:
    Codice:
    typedef elemento *Listadidipendenti;
  • studia la struttura degli array di char, in particolare tieni presente che il carattere terminatore è '\0' non '0' e che è sufficiente che il primo elemento sia '\0' per rendere la stringa vuota
  • dai una letta alla documentazione di scanf e printf, in particolare per quanto riguarda il formato %s
  • mantieni uno stile di indentazione costante
  • mantieni una convenzione di nomenclatura costante
  • dichiara un main canonico (tipo di dato in uscita, exit con codice di uscita alla fine)
  • se sono presenti dei malloc ci vogliono anche dei free (in un programmino con esecuzione singola come questo non sono assolutamente fondamentali, ma sono dell'avviso che sia meglio essere puntigliosi su questo argomento)

Frammenti esemplicativi:
Codice:
struct dipendente
{
  char nome[ LENGTH_NOME ];
  Data datassunzione;
};
typedef struct dipendente Dipendente;

struct elemento
{
  Dipendente info;
  struct elemento *next;
};
typedef struct elemento El;

void InserisciDati( El **lista, const int numero )
{
  int i;
  El *aux;
  for( i = 1; i <= numero; ++i )
  {
    aux = (El*)malloc( sizeof( El ) );
    memset( (void*)aux, 0x00, sizeof( El ) );
    printf( "\nInserire il nome del dipendente numero %d: ", i );
    scanf( "%s", aux->info.nome );

    printf( "Inserire la data di assunzione.\n" );
    printf( "Giorno: " );
    scanf( "%d", &aux->info.datassunzione.giorno );
    printf( "Mese: " );
    scanf( "%d", &aux->info.datassunzione.mese );
    printf( "Anno: " );
    scanf( "%d", &aux->info.datassunzione.anno );

    aux->next = *lista;
    *lista = aux;
  }
}
__________________
~Breve riferimento ai comandi GNU/Linux (ormai non molto breve...)
Gimli[2BV!2B] è offline   Rispondi citando il messaggio o parte di esso
Old 19-05-2011, 01:28   #3
Krat0s
Member
 
Iscritto dal: Jun 2008
Messaggi: 109
Domani do un'occhiata più lucida a ciò che hai scritto e al codice....a caldo ti posso dire che il typedef che mi hai segnalato lo usa la prof nel codice e almeno per ora ce lo devo mettere perchè è una che vuole vedere le cose scritte come le spiega lei....per l'immissione del nome non abbiamo visto le stringhe, quindi ho fatto un pò a caso....darò un'occhiata, e cerco di snellire il tutto. Ma sul codice hai visto qualche errore che mi può pregiudicare il funzionamento del programma?
Krat0s è offline   Rispondi citando il messaggio o parte di esso
Old 19-05-2011, 02:12   #4
Gimli[2BV!2B]
Senior Member
 
L'Avatar di Gimli[2BV!2B]
 
Iscritto dal: Feb 2006
Città: Parma
Messaggi: 3010
Direi che non torna la dimensione di questo malloc:
Codice:
void Inseriscidati(Listadidipendenti *lista,int numero)
{
     int i,j;
     char c;
     Listadidipendenti aux;
     for (i=1;i<=numero;i++) {
                               aux=malloc(sizeof(dip));
dipendente/dip è solo una porzione El/elemento.

Poi c'è un errore nelle stringhe Krat0s: tutti gli info.nome iniziano con un cararattere '0' per colpa di j.
__________________
~Breve riferimento ai comandi GNU/Linux (ormai non molto breve...)
Gimli[2BV!2B] è offline   Rispondi citando il messaggio o parte di esso
Old 19-05-2011, 09:57   #5
Krat0s
Member
 
Iscritto dal: Jun 2008
Messaggi: 109
Perfetto, corretti gli errori....poi mi metterò a sistemare il resto ed ottimizzare il tutto...grazie per l'aiuto
Krat0s è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Nioh 3: souls-like punitivo e Action RPG Nioh 3: souls-like punitivo e Action RPG
Test in super anteprima di Navimow i220 LiDAR: il robot tagliaerba per tutti Test in super anteprima di Navimow i220 LiDAR: i...
Dark Perk Ergo e Sym provati tra wireless, software via browser e peso ridotto Dark Perk Ergo e Sym provati tra wireless, softw...
DJI RS 5: stabilizzazione e tracking intelligente per ogni videomaker DJI RS 5: stabilizzazione e tracking intelligent...
AMD Ryzen 7 9850X3D: Zen 5, 3D V-Cache e frequenze al top per il gaming AMD Ryzen 7 9850X3D: Zen 5, 3D V-Cache e frequen...
Svolta Polestar per la ricarica: Plug&am...
Windows 11, cali di prestazioni sulle GP...
QNAP lancia myQNAPcloud One: l'archiviaz...
Clamoroso in Formula 1: FIA pronta a cam...
iPhone 18 Pro Max con batteria da oltre ...
L'UE dà ragione ad Apple: Maps e ...
Droni accecati e comunicazioni isolate: ...
Accesso alla memoria su Windows 11 solo ...
Regali di San Valentino: 15 idee tech sf...
Stellantis a picco in Borsa: 22 miliardi...
Baldur's Gate 3 diventa una serie TV: pr...
Intel riapre la sfida con Steam Deck: Pa...
Pompa di calore vs Caldaia, si risparmia...
AirDrop su Android? Quick Share sta per ...
iOS 27: Apple ridimensiona il progetto A...
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: 12:47.


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