Torna indietro   Hardware Upgrade Forum > Software > Programmazione

L'Europa conta nella tecnologia e può essere autonoma. Cosa si è detto al Nextcloud Summit 2026
L'Europa conta nella tecnologia e può essere autonoma. Cosa si è detto al Nextcloud Summit 2026
La parola d'ordine al Nextcloud Summit 2026, che si è tenuto a Monaco, è stata "sovranità". Non come è spesso usato questo termine in politica ma, al contrario, come capacità positiva di decidere il proprio destino tecnologico, con modalità collaborative e aperte. L'Europa dice già molto nel mondo open source, che viene visto come mezzo per ottenere la tanto agognata autonomia digitale
Dreame X60 Pro Ultra Complete: i bracci si estendono sempre di più
Dreame X60 Pro Ultra Complete: i bracci si estendono sempre di più
Dreame X60 Pro Ultra Complete implementa due bracci estensibili, per spazzola e moccio, che si spingono ben oltre quanto visto sino ad oggi permettendo una pulizia di casa ancor più capillare e precisa
TCL 65C8L, la recensione del SQD-Mini LED da 4400 nit misurati
TCL 65C8L, la recensione del SQD-Mini LED da 4400 nit misurati
La tecnologia SQD-Mini LED di TCL arriva sul taglio da 65 pollici con la serie C8L: 2040 zone, pannello WHVA 2.0 e un picco che alle rilevazioni delle sonde tocca i 4400 nit nel profilo Filmmaker e un HDR quasi perfetto
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 18-08-2007, 09:42   #1
xbubbax
Senior Member
 
Iscritto dal: Apr 2007
Messaggi: 381
[C] Esercizi su strutture e liste

Mi date una mano a capire questi esercizi? E' arabo per me, pensavo di aver capito le strutture e le liste invece questi mi sembrano difficili





ESERCIZIO 1

int confronta(struct interoillimitato *m, struct interoillimitato *n)
restituisce 1 se m è minore di n, 0 se sono uguali e -1 se n è minore di m
xbubbax è offline   Rispondi citando il messaggio o parte di esso
Old 18-08-2007, 10:15   #2
71104
Bannato
 
L'Avatar di 71104
 
Iscritto dal: Feb 2005
Città: Roma
Messaggi: 7029
io procederei così: tanto per cominciare confronta le lunghezze dei due numeri in input, la lunghezza maggiore appartiene al numero maggiore. se le lunghezze sono uguali allora passi a testare le singole cifre dei due numeri con un ciclo partendo dalle più significative verso le meno significative; non appena incontri due cifre diverse sei in grado di determinare il numero maggiore e puoi interrompere il ciclo e ritornare subito, altrimenti se riesci a concludere il ciclo e a verificare l'uguaglianza di tutte le cifre allora i due numeri sono identici. cosa non ti è chiaro?
71104 è offline   Rispondi citando il messaggio o parte di esso
Old 18-08-2007, 10:32   #3
xbubbax
Senior Member
 
Iscritto dal: Apr 2007
Messaggi: 381
Non ho capito proprio la prima parte, quell'immagine che ho postato, cioè tutte quelle dichiarazioni ecc..

sei hai tempo mi fai vedere come si inizializza il tutto nel modo piu semplice possibile,cose forse riesco a capire
xbubbax è offline   Rispondi citando il messaggio o parte di esso
Old 18-08-2007, 11:00   #4
71104
Bannato
 
L'Avatar di 71104
 
Iscritto dal: Feb 2005
Città: Roma
Messaggi: 7029
supponiamo che io debba utilizzare quella roba per memorizzare il numero 24:
Codice:
struct Number n1, n2;
struct InteroIllimitato i;

n1.value = 4;
n1.next = &n2;

n2.value = 2;
n2.next = NULL;

i.length = 2;
i.firstNumber = &n1;
i.lastNumber = &n2;
me in realtà a te non serve scrivere codice di inizializzazione.
71104 è offline   Rispondi citando il messaggio o parte di esso
Old 18-08-2007, 11:35   #5
xbubbax
Senior Member
 
Iscritto dal: Apr 2007
Messaggi: 381
ok, l'inizializzazione l'ho capita ora vedo di capire cosa fa l'esercizio
xbubbax è offline   Rispondi citando il messaggio o parte di esso
Old 18-08-2007, 11:36   #6
xbubbax
Senior Member
 
Iscritto dal: Apr 2007
Messaggi: 381
ma la funzione cosa deve fare?

deve confrontare i numeri memorizzati in n1 e n2 o cosa?
non l'ho capito
xbubbax è offline   Rispondi citando il messaggio o parte di esso
Old 18-08-2007, 11:49   #7
71104
Bannato
 
L'Avatar di 71104
 
Iscritto dal: Feb 2005
Città: Roma
Messaggi: 7029
sostanzialmente deve confrontare tutte le struct Number contenute nelle liste specificate da n ed m, ma per i dettagli sull'algoritmo vedi post #2.
71104 è offline   Rispondi citando il messaggio o parte di esso
Old 18-08-2007, 11:52   #8
71104
Bannato
 
L'Avatar di 71104
 
Iscritto dal: Feb 2005
Città: Roma
Messaggi: 7029
faccio un altro esempio di inizializzazione, giusto per chiarire che una di quelle liste può contenere anche molto più di due cifre; supponiamo di voler memorizzare il numero 123:
Codice:
struct Number n1, n2, n3;
struct InteroIllimitato i;

n1.value = 3;
n1.next = &n2;

n2.value = 2;
n2.next = &n3;

n3.value = 1;
n3.next = NULL;

i.length = 3;
i.firstNumber = &n1;
i.lastNumber = &n3;
la struttura InteroIllimitato può descrivere una lista di lunghezza arbitraria, e può quindi contenere dozzine di cifre.
71104 è offline   Rispondi citando il messaggio o parte di esso
Old 18-08-2007, 11:54   #9
xbubbax
Senior Member
 
Iscritto dal: Apr 2007
Messaggi: 381
allora, tu hai creato una struttura di tipo number chiamata n1 e una chiamata n2 e in oguna di queste strutture hai inizializzato la variabile value rispettivamente a 4 e 2.

poi hai creato una struttura di tipo interoillimitato chiamata i e hai inizializzato la lunghezza a 2(perchè?) e hai inizializzato i due puntatori, uno a n1 e uno a n2.

Mi puoi spiegare a parole cosa chiede l'esercizio?
xbubbax è offline   Rispondi citando il messaggio o parte di esso
Old 18-08-2007, 11:55   #10
xbubbax
Senior Member
 
Iscritto dal: Apr 2007
Messaggi: 381
ho visto anche la tua seconda inizializzazione, ora mi è tutto chiaro. ma non capisco cosa chiede l'esercizio.
xbubbax è offline   Rispondi citando il messaggio o parte di esso
Old 18-08-2007, 11:57   #11
71104
Bannato
 
L'Avatar di 71104
 
Iscritto dal: Feb 2005
Città: Roma
Messaggi: 7029
Quote:
Originariamente inviato da xbubbax Guarda i messaggi
poi hai creato una struttura di tipo interoillimitato chiamata i e hai inizializzato la lunghezza a 2(perchè?)
perché mi apprestavo a creare una lista di lunghezza 2, cioè contenente 2 elementi (n1 ed n2). nell'altro esempio invece la lunghezza l'ho impostata a 3 perché ci sono 3 elementi.

Quote:
Mi puoi spiegare a parole cosa chiede l'esercizio?
di confrontare i due numeri n ed m che arrivano in ingresso come parametri. n ed m sono in realtà due struct che descrivono altrettante liste di cifre decimali, quindi n ed m rappresentano dei numeri.
71104 è offline   Rispondi citando il messaggio o parte di esso
Old 18-08-2007, 12:00   #12
xbubbax
Senior Member
 
Iscritto dal: Apr 2007
Messaggi: 381
non capisco ancora, non ci riuscirò mai..


quindi devo confrontare due numeri n e m, cioè due liste? come quella che hai creato?

solo che ne devo fare due e confrontarle?
xbubbax è offline   Rispondi citando il messaggio o parte di esso
Old 18-08-2007, 12:05   #13
xbubbax
Senior Member
 
Iscritto dal: Apr 2007
Messaggi: 381
Codice HTML:
#include <stdio.h>
struct Number{
       int value;
       struct Number *next;};
struct Interoillimitato{
       int lenght;
       struct Number *firstnumber;
       struct Number *lastnumber;};
int main(){
           
           struct Number n1, n2, n3, n4;
           struct Interoillimitato i;
           
           n1.value=4;
           n1.next=&n2;
           
           n2.value=3;
           n2.next=&n3;
           
           n3.value=2;
           n3.next=&n4;
           
           n4.value=1;
           n4.next=NULL;
           
           i.lenght=4;
           i.firstnumber=&n1;
           i.lastnumber=&n4;

Ho scritto questo, cioè ho creato una lista di 4 elementi, 4->3->2->1->NULL

ora che devo fare?
xbubbax è offline   Rispondi citando il messaggio o parte di esso
Old 18-08-2007, 12:18   #14
71104
Bannato
 
L'Avatar di 71104
 
Iscritto dal: Feb 2005
Città: Roma
Messaggi: 7029
Quote:
Originariamente inviato da xbubbax Guarda i messaggi
ora che devo fare?
scrivi il codice della funzione "confronta" descritta nel testo dell'esercizio 1. comincia col controllo basilare: se un numero ha più cifre di un altro è sicuramente maggiore, no?
71104 è offline   Rispondi citando il messaggio o parte di esso
Old 18-08-2007, 12:32   #15
xbubbax
Senior Member
 
Iscritto dal: Apr 2007
Messaggi: 381
scusa la mia ignoranza ma non ho capito proprio cosa deve fare la funziona

cioè io ho una lista di 4 elementi e una struttura dove c'è scritto il numero di elementi che ha la lista e c'è un puntatore al primo e uno all'ultimo numero della lista

ora cosa devo farci con questa lista?

non bisogna creare 2 liste per confrontare 2 numeri?
xbubbax è offline   Rispondi citando il messaggio o parte di esso
Old 18-08-2007, 13:07   #16
xbubbax
Senior Member
 
Iscritto dal: Apr 2007
Messaggi: 381
cioè ho capito come va svolto l'esercizio ma non so su cosa devo lavorare all'interno della funzione e quali sono i due numeri da confrontare. devo confrontare due liste o cosa?

mi serve un aiutino, un input, poi cerco di farlo da solo
xbubbax è offline   Rispondi citando il messaggio o parte di esso
Old 18-08-2007, 14:20   #17
71104
Bannato
 
L'Avatar di 71104
 
Iscritto dal: Feb 2005
Città: Roma
Messaggi: 7029
guarda la dichiarazione della funzione: ci sono due parametri, m ed n, che rispettivamente puntano a due diverse "struct InteroIllimitato" ciascuna delle quali descrive una diversa lista di cifre decimali. ricevi in input le descrizioni di due liste diverse che corrispondono a due numeri diversi, e tu devi confrontare questi due numeri e ritornare 1 se è minore il primo, 0 se sono uguali e -1 se è maggiore il primo.
71104 è offline   Rispondi citando il messaggio o parte di esso
Old 18-08-2007, 16:12   #18
xbubbax
Senior Member
 
Iscritto dal: Apr 2007
Messaggi: 381
penso di aver capito.

domani ci provo
xbubbax è offline   Rispondi citando il messaggio o parte di esso
Old 19-08-2007, 09:00   #19
xbubbax
Senior Member
 
Iscritto dal: Apr 2007
Messaggi: 381
Ho provato a farlo, ditemi tutto quello che ho sbagliato

Codice HTML:
#include <stdio.h>
int confronta(struct interoillimitato *m, struct interoillimitato *n);
struct Number{
       int value;
       struct Number *next;};
struct Interoillimitato{
       int lenght;
       struct Number *firstnumber;
       struct Number *lastnumber;};
int main(){
           
           struct Number n1, n2, n3, n4;
           struct Number m1, m2, m3, m4;
           struct Interoillimitato m;
           struct Interoillimitato n;
           
           n1.value=4;
           n1.next=&n2;
           
           n2.value=3;
           n2.next=&n3;
           
           n3.value=2;
           n3.next=&n4;
           
           n4.value=1;
           n4.next=NULL;
           
           n.lenght=4;
           n.firstnumber=&n1;
           n.lastnumber=&n4;
           
           m1.value=3;
           m1.next=&m2;
           
           m2.value=7;
           m2.next=&m3;
           
           m3.value=2;
           m3.next=&m4;
           
           m4.value=6;
           m4.next=NULL;
           
           m.lenght=4;
           m.firstnumber=&m1;
           m.lastnumber=&m4;
           
           printf("%d\n", confronta(Interoillimitato m, Interoillimitato n));
           
           }
int confronta(struct interoillimitato *m, struct interoillimitato *n){
    int risultato=0;
    
    if(m.lenght>n.lenght){
                          risultato=-1;}
    if(m.lenght<n.lenght){
                          risultato=1;} else { for(i=0;i<m.lenght;i++){
                                                                       if(m.firstnumber>n.firstnumber){
                                                                                                       risultato=-1; break;}
                                                                       if(m.firstnumber<n.firstnumber){
                                                                                                       risultato=1; break;} else 
                                                                                                       {m.firstnumber=m.firstnumber->next;
                                                                                                       n.firstnumber=n.firstnumber->next;}}
                                                                                                       
                                                                       return risultato;}
                            
                          
    
    

Ultima modifica di xbubbax : 19-08-2007 alle 09:08.
xbubbax è offline   Rispondi citando il messaggio o parte di esso
Old 20-08-2007, 08:23   #20
LetBloodline
Junior Member
 
Iscritto dal: Jul 2007
Messaggi: 27
Quote:
Originariamente inviato da xbubbax Guarda i messaggi
Ho provato a farlo, ditemi tutto quello che ho sbagliato

Codice HTML:
#include <stdio.h>
int confronta(struct interoillimitato *m, struct interoillimitato *n);
struct Number{
       int value;
       struct Number *next;};
struct Interoillimitato{
       int lenght;
       struct Number *firstnumber;
       struct Number *lastnumber;};
int main(){
           
           struct Number n1, n2, n3, n4;
           struct Number m1, m2, m3, m4;
           struct Interoillimitato m;
           struct Interoillimitato n;
           
           n1.value=4;
           n1.next=&n2;
           
           n2.value=3;
           n2.next=&n3;
           
           n3.value=2;
           n3.next=&n4;
           
           n4.value=1;
           n4.next=NULL;
           
           n.lenght=4;
           n.firstnumber=&n1;
           n.lastnumber=&n4;
           
           m1.value=3;
           m1.next=&m2;
           
           m2.value=7;
           m2.next=&m3;
           
           m3.value=2;
           m3.next=&m4;
           
           m4.value=6;
           m4.next=NULL;
           
           m.lenght=4;
           m.firstnumber=&m1;
           m.lastnumber=&m4;
           
           printf("%d\n", confronta(Interoillimitato m, Interoillimitato n));
           
           }
int confronta(struct interoillimitato *m, struct interoillimitato *n){
    int risultato=0;
    
    if(m.lenght>n.lenght){
                          risultato=-1;}
    if(m.lenght<n.lenght){
                          risultato=1;} else { for(i=0;i<m.lenght;i++){
                                                                       if(m.firstnumber>n.firstnumber){
                                                                                                       risultato=-1; break;}
                                                                       if(m.firstnumber<n.firstnumber){
                                                                                                       risultato=1; break;} else 
                                                                                                       {m.firstnumber=m.firstnumber->next;
                                                                                                       n.firstnumber=n.firstnumber->next;}}
                                                                                                       
                                                                       return risultato;}
                            
                          
    
    
tanto per cominciare il return viene eseguito all'interno del ciclo for mentre devi eseguirlo per ultima cosa esterna a tutti i cicli e a tutti gli if. Devi chiudere ancora una parentesi grafa prima del return
LetBloodline è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


L'Europa conta nella tecnologia e può essere autonoma. Cosa si è detto al Nextcloud Summit 2026 L'Europa conta nella tecnologia e può ess...
Dreame X60 Pro Ultra Complete: i bracci si estendono sempre di più Dreame X60 Pro Ultra Complete: i bracci si esten...
TCL 65C8L, la recensione del SQD-Mini LED da 4400 nit misurati TCL 65C8L, la recensione del SQD-Mini LED da 440...
MSI Maestro 500 Wireless: ANC e 90 ore di autonomia a 70 euro MSI Maestro 500 Wireless: ANC e 90 ore di autono...
NL-LC1 è il primo dissipatore a liquido AIO di Noctua: silenzio è la parola d'ordine NL-LC1 è il primo dissipatore a liquido A...
Dopo gli unicorni, arrivano i "soon...
Europei sempre più diffidenti ver...
L'acquisto di Steam Machine è un ...
Lenovo Prime Day: i 6 migliori sconti (a...
CATL non riesce a superare la fase proto...
Mythos, il caso si complica: causa contr...
Il pazzesco nuovo record di Xiaomi YU7 G...
OneXPlayer 3: un PC gaming in formato Ni...
Climate.us riporta online i 15 anni di C...
Hisense da 58 pollici sotto i 300€ fa tr...
Windows 11 26H2: cosa cambia e chi resta...
SpaceX ha lanciato la sua prima capsula ...
Il prezzo medio di vendita degli smartph...
Prime Day robot tagliaerba: MAMMOTION, D...
Recensione Google Home Speaker: Gemini s...
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: 19:42.


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