Torna indietro   Hardware Upgrade Forum > Software > Programmazione

HONOR Magic 8 Pro: ecco il primo TOP del 2026! La recensione
HONOR Magic 8 Pro: ecco il primo TOP del 2026! La recensione
HONOR ha finalmente lanciato il suo nuovo flagship: Magic 8 Pro. Lo abbiamo provato a fondo in queste settimane e ve lo raccontiamo nella nostra recensione completa. HONOR rimane fedele alle linee della versione precedente, aggiungendo però un nuovo tasto dedicato all'AI. Ma è al suo interno che c'è la vera rivoluzione grazie al nuovo Snapdragon 8 Elite Gen 5 e alla nuova MagicOS 10
Insta360 Link 2 Pro e 2C Pro: le webcam 4K che ti seguono, anche con gimbal integrata
Insta360 Link 2 Pro e 2C Pro: le webcam 4K che ti seguono, anche con gimbal integrata
Le webcam Insta360 Link 2 Pro e Link 2C Pro sono una proposta di fascia alta per chi cerca qualità 4K e tracciamento automatico del soggetto senza ricorrere a configurazioni complesse. Entrambi i modelli condividono sensore, ottiche e funzionalità audio avanzate, differenziandosi per il sistema di tracciamento: gimbal a due assi sul modello Link 2 Pro, soluzione digitale sul 2C Pro
Motorola edge 70: lo smartphone ultrasottile che non rinuncia a batteria e concretezza
Motorola edge 70: lo smartphone ultrasottile che non rinuncia a batteria e concretezza
Motorola edge 70 porta il concetto di smartphone ultrasottile su un terreno più concreto e accessibile: abbina uno spessore sotto i 6 mm a una batteria di capacità relativamente elevata, un display pOLED da 6,7 pollici e un comparto fotografico triplo da 50 MP. Non punta ai record di potenza, ma si configura come alternativa più pragmatica rispetto ai modelli sottili più costosi di Samsung e Apple
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 19-06-2007, 16:17   #1
danny2005
Senior Member
 
L'Avatar di danny2005
 
Iscritto dal: Dec 2005
Città: Lingua di terra che taglia il Tirreno
Messaggi: 795
[C] un'occhiata al listato thanks

Un processo P conta il numero di servizi che ogni utente gli invia. Il processo P preleva le richieste da una stack, le elabora ed inserisce i risultati in una lista dinamica. Le richieste nello stack e gli elementi nella lista hanno le seguenti strutture:

struct richiesta
{

int codice_servizio;

char cognome [20];

}

struct elemento
{

char cognome [20];

int num_servizi;

}

Il processo P gestisce le richieste nel seguente modo:

- verifica che il codice_servizio della richiesta abbia un valore compreso tra 1 e 1024, altrimenti scarta la richiesta;
- verifica che nella lista, che è ordinata rispetto al campo cognome esista un elemento con lo stesso cognome presente nella richiesta.ùSe tale elemento è presente, ne incrementa di 1 unità la variabile num_servizi, altrimenti inserisce un nuovo elemento nella lista in maniera ordinata con il valore di num_servizi pari a 1.

Ecco come ci ho messo mano....
Codice:
#include <stdio.h>
#include <string.h>
#include <stdlib.h>

struct richiesta 
{
       int codice_servizio;
       char cognome [20];
       struct richiesta *next;
};

struct elemento 
{
        char cognome[20];
        int num_servizi;
        struct elemento *next;
};

PROTOTIPI DI FUNZIONE

struct elemento * preleva_richiesta_da_stack(struct richiesta **, struct richiesta **);

int elabora_elemento_stack (struct richiesta *);

void in_lista_ordinata (struct elemento **, struct elemento **);

int main ()
{
           struct richiesta * testa_stack=NULL;
           struct elemento *testa_lista=NULL;
           struct elemento *elem=NULL;
           struct richiesta * y=NULL;

            int codice, esci;

            while(!esci)
            {
                   esci=1;
                   elem= preleva_richiesta_da_stack(&testa_stack, &y);
                   codice= elabora_elemento_stack(y);

                   if (codice >=1 && codice <= 1024)
                   {
                         esci=0;
                         in_lista_ordinata(&testa_lista, &elem);
                   }

            }

retrurn 0;
}


DEFINIZIONE DELLE FUNZIONI

struct elemento * preleva_richiesta_da_stack(struct richiesta **head, struct richiesta ** query)

{
     struct elemento *new;
     new= (struct elemento *)malloc(sizeof(struct elemento));

     if (*head ==NULL)
     printf("Errore stack vuota!\n");

   else
     { 
           *query=*head;
            *head= (*head)-> next;
      }

        strcpy(new->cognome, (*query)->cognome);
        new->num_servizi= (*query)->codice_servizio;

        return new;
}

int elabora_elemento_stack(struct richiesta *punt)
{

      return (punt->codice_servizio);

}

void in_lista_ordinata(struct elemento **head, struct elemento ** element)

{         struct elemento *prec, *curr, *new;
           new=(struct elemento *)malloc(sizeof(struct elemento));
           strcpy (new->cognome, (*element)->cognome);
           new->num_servizi= (*element)->num_servizi;

           prec=NULL;
           curr=*head;

           while(curr != NULL && strcmp( curr->cognome, new->cognome)<=0)
           {


[ho bisogno di allocare lo spazio per il puntatore new e ricopiare li dentro il tutto, oppure confronto direttamente *element con curr? io eviterei di usare new, voi che dite?]

                 if(strcmp(curr->cognome, new->cognome)==0)

                 (curr->num_servizi)++;

                else 
                {
                     prec=curr;
                     curr=curr->next;
                } 

          }

    if(prec==NULL)
    {       new-<next=*head;
             *head=new;
             new->num_servizi =1;
    }

     else
      {
           prec->next=new;
           new->next=curr;
           new->num_servizi =1;
      }

}
senza new ci sarebbe *element nei vari passaggi
__________________
Il Paradiso lo preferisco per il clima, l'Inferno per la compagnia [Mark Twain] [Romantico Inside][Thread prof. gnocche]

Ultima modifica di danny2005 : 28-06-2007 alle 11:21.
danny2005 è offline   Rispondi citando il messaggio o parte di esso
Old 21-06-2007, 18:26   #2
danny2005
Senior Member
 
L'Avatar di danny2005
 
Iscritto dal: Dec 2005
Città: Lingua di terra che taglia il Tirreno
Messaggi: 795
up

nessuno che si sbilancia?
__________________
Il Paradiso lo preferisco per il clima, l'Inferno per la compagnia [Mark Twain] [Romantico Inside][Thread prof. gnocche]
danny2005 è offline   Rispondi citando il messaggio o parte di esso
Old 25-06-2007, 13:39   #3
danny2005
Senior Member
 
L'Avatar di danny2005
 
Iscritto dal: Dec 2005
Città: Lingua di terra che taglia il Tirreno
Messaggi: 795
up up up
__________________
Il Paradiso lo preferisco per il clima, l'Inferno per la compagnia [Mark Twain] [Romantico Inside][Thread prof. gnocche]
danny2005 è offline   Rispondi citando il messaggio o parte di esso
Old 25-06-2007, 15:21   #4
Ziosilvio
Moderatore
 
L'Avatar di Ziosilvio
 
Iscritto dal: Nov 2003
Messaggi: 16213
Faresti bene a usare il tag "code" e a sfruttare l'indentazione.
Codice:
struct elemento * preleva_richiesta_da_stack(struct richiesta **head, struct richiesta ** query)

{
  struct elemento *new;
  new= (struct elemento *)malloc(sizeof(struct elemento));
  if (*head ==NULL)
    printf("Errore stack vuota!\n");
  else
  { *query=*head;
    *head= (*head)-> next;
  }

  strcpy(new->cognome, (*query)->cognome);
  new->num_servizi= (*query)->codice_servizio;

  return new;
}
Perché la copia dei campi avviene anche se non c'è spazio per new?

Nella parte successiva puoi fare i confronti direttamente, senza bisogno di creare una copia.
Codice:
void in_lista_ordinata(struct elemento **head, struct elemento ** element)

{ struct elemento *prec, *curr, *new;
  new=(struct elemento *)malloc(sizeof(struct elemento));
  strcpy (new->cognome, (*element)->cognome);
  new->num_servizi= (*element)->num_servizi;

  prec=NULL;
  curr=*head;

  while(curr != NULL && strcmp( curr->cognome, new->cognome)<=0)

  { if(strcmp(curr->cognome, new->cognome)==0
Qui ci va una parentesi tonda chiusa.
Codice:
      (curr->num_servizi)++;

    else {

      prec=curr;

      curr=curr->next;
    }
  }

  if(prec==NULL)

  { new-<next=*head;
    *head=new;
    new->num_servizi =1;
  }
  else
  {
    prec->next=new;
    new->next=curr;
    new->num_servizi =1;
  }
}
Qui c'è un problema: prec può essere NULL non solo all'inizio, ma anche se viene inserito un nominativo che precede, in ordine alfabetico, tutti quelli della lista.
__________________
Ubuntu è un'antica parola africana che significa "non so configurare Debian" Chi scherza col fuoco si brucia.
Scienza e tecnica: Matematica - Fisica - Chimica - Informatica - Software scientifico - Consulti medici
REGOLAMENTO DarthMaul = Asus FX505 Ryzen 7 3700U 8GB GeForce GTX 1650 Win10 + Ubuntu

Ultima modifica di Ziosilvio : 25-06-2007 alle 15:24.
Ziosilvio è offline   Rispondi citando il messaggio o parte di esso
Old 28-06-2007, 10:04   #5
cionci
Senior Member
 
L'Avatar di cionci
 
Iscritto dal: Apr 2000
Città: Vicino a Montecatini(Pistoia) Moto:Kawasaki Ninja ZX-9R Scudetti: 29
Messaggi: 53971
Prima di tutto dai una bella indentata a tutto il codice seguendo uno dei metodi classici del C...

Ad esempio:
Codice:
int pippo(int pluto, int paperino)
{
    if(pluto = paperino)
    {
         return 1;
    }
    else
    {
         return 0;
    }
}
Soprattutto per le parentesi è importantissimo che siano messe secondo una logica, altrimenti non ci si capisce niente...
cionci è offline   Rispondi citando il messaggio o parte di esso
Old 28-06-2007, 10:58   #6
cionci
Senior Member
 
L'Avatar di cionci
 
Iscritto dal: Apr 2000
Città: Vicino a Montecatini(Pistoia) Moto:Kawasaki Ninja ZX-9R Scudetti: 29
Messaggi: 53971
Ancora non ci siamo...ti faccio vedere il main come lo farei io:
Codice:
int main ()
{
    struct richiesta * testa_stack = NULL;
    struct elemento *testa_lista = NULL;
    struct elemento *elem = NULL;
    struct richiesta * y = NULL;

    int codice, esci;

    while(!esci)
    {
        esci = 1;
        elem = preleva_richiesta_da_stack(&testa_stack, &y);
        codice = elabora_elemento_stack(y);

        if(codice >= 1 && codice <= 1024)
        {
             esci = 0;
             in_lista_ordinata(&testa_lista, &elem);
        }
    }

    return 0;
}

Ultima modifica di cionci : 28-06-2007 alle 11:02.
cionci è offline   Rispondi citando il messaggio o parte di esso
Old 28-06-2007, 11:33   #7
cionci
Senior Member
 
L'Avatar di cionci
 
Iscritto dal: Apr 2000
Città: Vicino a Montecatini(Pistoia) Moto:Kawasaki Ninja ZX-9R Scudetti: 29
Messaggi: 53971
Ancora no...i blocchi che sono allo stesso livello devono essere allineati...
Che editor usi per scrivere il codice ? Molti editor permettono di usare il tab per indentare il codice, tab che viene poi convertito in un numero di spazi impostabile a piacere (solitamente 3 o 4)...
cionci è offline   Rispondi citando il messaggio o parte di esso
Old 28-06-2007, 11:38   #8
danny2005
Senior Member
 
L'Avatar di danny2005
 
Iscritto dal: Dec 2005
Città: Lingua di terra che taglia il Tirreno
Messaggi: 795
Quote:
Originariamente inviato da cionci Guarda i messaggi
Ancora no...i blocchi che sono allo stesso livello devono essere allineati...
Che editor usi per scrivere il codice ? Molti editor permettono di usare il tab per indentare il codice, tab che viene poi convertito in un numero di spazi impostabile a piacere (solitamente 3 o 4)...
Il fatto è che non uso editor...l'ho scritto a mano qua...

cmq se puoi fare uno sforzo......(per stavolta)

Non lo faccio più...giuro......
__________________
Il Paradiso lo preferisco per il clima, l'Inferno per la compagnia [Mark Twain] [Romantico Inside][Thread prof. gnocche]
danny2005 è offline   Rispondi citando il messaggio o parte di esso
Old 28-06-2007, 11:53   #9
cionci
Senior Member
 
L'Avatar di cionci
 
Iscritto dal: Apr 2000
Città: Vicino a Montecatini(Pistoia) Moto:Kawasaki Ninja ZX-9R Scudetti: 29
Messaggi: 53971
Tanto gli editor la fanno da soli la formattazione
Codice:
#include <stdio.h>
#include <string.h>
#include <stdlib.h>

struct richiesta
{
	int codice_servizio;
	char cognome[20];
	struct richiesta *next;
};

struct elemento
{
	char cognome[20];
	int num_servizi;
	struct elemento *next;
};

/*PROTOTIPI DI FUNZIONE*/
struct elemento *preleva_richiesta_da_stack (struct richiesta **,
					     struct richiesta **);

int elabora_elemento_stack (struct richiesta *);

void in_lista_ordinata (struct elemento **, struct elemento **);

int
main ()
{
	struct richiesta *testa_stack = NULL;
	struct elemento *testa_lista = NULL;
	struct elemento *elem = NULL;
	struct richiesta *y = NULL;

	int codice, esci;

	while (!esci)
	{
		esci = 1;
		elem = preleva_richiesta_da_stack (&testa_stack, &y);
		codice = elabora_elemento_stack (y);

		if (codice >= 1 && codice <= 1024)
		{
			esci = 0;
			in_lista_ordinata (&testa_lista, &elem);
		}

	}

	retrurn 0;
}


/*DEFINIZIONE DELLE FUNZIONI */
struct elemento *
preleva_richiesta_da_stack (struct richiesta **head, struct richiesta **query)
{
	struct elemento *new;
	new = (struct elemento *) malloc (sizeof (struct elemento));

	if (*head == NULL)
		printf ("Errore stack vuota!\n");

	else
	{
		*query = *head;
		*head = (*head)->next;
	}

	strcpy (new->cognome, (*query)->cognome);
	new->num_servizi = (*query)->codice_servizio;

	return new;
}

int
elabora_elemento_stack (struct richiesta *punt)
{

	return (punt->codice_servizio);

}

void
in_lista_ordinata (struct elemento **head, struct elemento **element)
{
	struct elemento *prec, *curr, *new;
	new = (struct elemento *) malloc (sizeof (struct elemento));
	strcpy (new->cognome, (*element)->cognome);
	new->num_servizi = (*element)->num_servizi;

	prec = NULL;
	curr = *head;

	while (curr != NULL && strcmp (curr->cognome, new->cognome) <= 0)
	{
		/*[ho bisogno di allocare lo spazio per il puntatore new e
		 * ricopiare li dentro il tutto,
		 * oppure confronto direttamente *
		 * element con curr ? io eviterei di usare new,
		 * voi che dite ?] */
		if (strcmp (curr->cognome, new->cognome) == 0)
			(curr->num_servizi)++;
		else
		{
			prec = curr;
			curr = curr->next;
		}

	}

	if (prec == NULL)
	{
		new - <next = *head;
		*head = new;
		new->num_servizi = 1;
	}
	else
	{
		prec->next = new;
		new->next = curr;
		new->num_servizi = 1;
	}

}
cionci è offline   Rispondi citando il messaggio o parte di esso
Old 28-06-2007, 11:56   #10
danny2005
Senior Member
 
L'Avatar di danny2005
 
Iscritto dal: Dec 2005
Città: Lingua di terra che taglia il Tirreno
Messaggi: 795
ok ma...va bene? non parlo dell'indentazione ma di ciò che è indentato........
__________________
Il Paradiso lo preferisco per il clima, l'Inferno per la compagnia [Mark Twain] [Romantico Inside][Thread prof. gnocche]
danny2005 è offline   Rispondi citando il messaggio o parte di esso
Old 28-06-2007, 12:05   #11
cionci
Senior Member
 
L'Avatar di cionci
 
Iscritto dal: Apr 2000
Città: Vicino a Montecatini(Pistoia) Moto:Kawasaki Ninja ZX-9R Scudetti: 29
Messaggi: 53971
Se funziona va bene
L'hai provato ?
cionci è offline   Rispondi citando il messaggio o parte di esso
Old 28-06-2007, 12:18   #12
danny2005
Senior Member
 
L'Avatar di danny2005
 
Iscritto dal: Dec 2005
Città: Lingua di terra che taglia il Tirreno
Messaggi: 795
ancora no......
è che volevo un parere da uno esperto; per essere sicuro di non aver scritto cose strane.........
__________________
Il Paradiso lo preferisco per il clima, l'Inferno per la compagnia [Mark Twain] [Romantico Inside][Thread prof. gnocche]

Ultima modifica di danny2005 : 28-06-2007 alle 12:20.
danny2005 è offline   Rispondi citando il messaggio o parte di esso
Old 28-06-2007, 12:27   #13
cionci
Senior Member
 
L'Avatar di cionci
 
Iscritto dal: Apr 2000
Città: Vicino a Montecatini(Pistoia) Moto:Kawasaki Ninja ZX-9R Scudetti: 29
Messaggi: 53971
Tanto l'insegnante migliore è il compilatore...
Se non l'avessi scritto tutto insieme ora avresti potuto fare varie prove prima di terminarlo per vedere se quello che stavi facendo era corretto
cionci è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


HONOR Magic 8 Pro: ecco il primo TOP del 2026! La recensione HONOR Magic 8 Pro: ecco il primo TOP del 2026! L...
Insta360 Link 2 Pro e 2C Pro: le webcam 4K che ti seguono, anche con gimbal integrata Insta360 Link 2 Pro e 2C Pro: le webcam 4K che t...
Motorola edge 70: lo smartphone ultrasottile che non rinuncia a batteria e concretezza Motorola edge 70: lo smartphone ultrasottile che...
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...
TikTok chiarisce il funzionamento della ...
Samsung Galaxy A07 5G: il nuovo entry le...
Realme 16 in arrivo: un mix tra iPhone A...
Domenica di follia su Amazon: iPhone 17 ...
Questo portatile HP OMEN con Core Ultra ...
Robot aspirapolvere al prezzo giusto: le...
Il nuovo M5 Max potrebbe avere una GPU p...
Pulizie automatiche al top (e a prezzo B...
Casa più calda, spese più leggere: Tado ...
Mini PC mostruoso in offerta nascosta su...
Netflix promette 45 giorni di esclusivit...
Gigabyte: un handheld? Sì, ma sol...
Samsung conferma l'arrivo di tre variant...
Sottile, veloce e con un'ottima autonomi...
Il top di gamma compatto di OnePlus &egr...
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: 18:43.


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