Torna indietro   Hardware Upgrade Forum > Software > Programmazione

I nuovi schermi QD-OLED di quinta generazione di MSI, per i gamers
I nuovi schermi QD-OLED di quinta generazione di MSI, per i gamers
MSI continua ad investire nel proporre schermi pensati per rispondere alle esigenze dei videogiocatori, utilizzando la quinta generazione di tecnologia QD-OLED sviluppata da Samsung. Il modello MGP 341CQR QD-OLED X36 è lpultima novità al debutto in concomitanza con il CES 2026, uno schermo curvo di ampia risoluzione pensato per i videogiocatori più esigenti
Recensione vivo X300 Pro: è ancora lui il re della fotografia mobile, peccato per la batteria
Recensione vivo X300 Pro: è ancora lui il re della fotografia mobile, peccato per la batteria
vivo X300 Pro rappresenta un'evoluzione misurata della serie fotografica del produttore cinese, con un sistema di fotocamere migliorato, chipset Dimensity 9500 di ultima generazione e l'arrivo dell'interfaccia OriginOS 6 anche sui modelli internazionali. La scelta di limitare la batteria a 5.440mAh nel mercato europeo, rispetto ai 6.510mAh disponibili altrove, fa storcere un po' il naso
Lenovo Legion Go 2: Ryzen Z2 Extreme e OLED 8,8'' per spingere gli handheld gaming PC al massimo
Lenovo Legion Go 2: Ryzen Z2 Extreme e OLED 8,8'' per spingere gli handheld gaming PC al massimo
Lenovo Legion Go 2 è la nuova handheld PC gaming con processore AMD Ryzen Z2 Extreme (8 core Zen 5/5c, GPU RDNA 3.5 16 CU) e schermo OLED 8,8" 1920x1200 144Hz. È dotata anche di controller rimovibili TrueStrike con joystick Hall effect e una batteria da 74Wh. Rispetto al dispositivo che l'ha preceduta, migliora ergonomia e prestazioni a basse risoluzioni, ma pesa 920g e costa 1.299€ nella configurazione con 32GB RAM/1TB SSD e Z2 Extreme
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 18-08-2007, 10: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, 11: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, 11: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, 12: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, 12: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, 12: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, 12: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, 12: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, 12: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, 12: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, 12: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, 13: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, 13: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, 13: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, 13: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, 14: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, 15: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, 17: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, 10: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 10:08.
xbubbax è offline   Rispondi citando il messaggio o parte di esso
Old 20-08-2007, 09: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


I nuovi schermi QD-OLED di quinta generazione di MSI, per i gamers I nuovi schermi QD-OLED di quinta generazione di...
Recensione vivo X300 Pro: è ancora lui il re della fotografia mobile, peccato per la batteria Recensione vivo X300 Pro: è ancora lui il...
Lenovo Legion Go 2: Ryzen Z2 Extreme e OLED 8,8'' per spingere gli handheld gaming PC al massimo Lenovo Legion Go 2: Ryzen Z2 Extreme e OLED 8,8'...
AWS re:Invent 2025: inizia l'era dell'AI-as-a-Service con al centro gli agenti AWS re:Invent 2025: inizia l'era dell'AI-as-a-Se...
Cos'è la bolla dell'IA e perché se ne parla Cos'è la bolla dell'IA e perché se...
La Russia prosegue lo sviluppo di reatto...
Roscosmos: da quest'anno ci potrà...
Amazon, tutte le offerte e qualche novit...
Sedie gaming in offerta su Amazon: desig...
Scope elettriche in offerta Amazon: mode...
Ricarica EV fino a 22 kW spendendo poco:...
Costa solo 139€ ma fa tutto: Lefant M330...
Amazon Haul spinge sul risparmio: sconti...
Oral-B iO in offerta su Amazon: maxi sco...
I cosmonauti avrebbero riparato tutte le...
Artemis II: la NASA conferma il lancio d...
Il CEO di Embrak Studios difende l'uso d...
Il Trump Phone è sempre più un mistero: ...
OPPO ha svelato la serie Reno 15 "global...
Poste ID diventa a pagamento: l'identità...
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:07.


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