Torna indietro   Hardware Upgrade Forum > Software > Programmazione

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
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-Service con al centro gli agenti
A re:Invent 2025, AWS mostra un’evoluzione profonda della propria strategia: l’IA diventa una piattaforma di servizi sempre più pronta all’uso, con agenti e modelli preconfigurati che accelerano lo sviluppo, mentre il cloud resta la base imprescindibile per governare dati, complessità e lock-in in uno scenario sempre più orientato all’hybrid cloud
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


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...
BOOX Palma 2 Pro in prova: l'e-reader diventa a colori, e davvero tascabile BOOX Palma 2 Pro in prova: l'e-reader diventa a ...
Il nuovo OnePlus Nord 6 è vicino al debu...
Tesla svela i risultati del Q4: conferma...
Nuova rimodulazione da Fastweb: fino a 3...
La NVIDIA RTX 5090 potrebbe presto costa...
ASUS non produrrà più smar...
CoopVoce sta per lanciare il 5G: ecco qu...
Factorial, azienda di batterie allo stat...
Le specifiche fuori di testa della Yangw...
I numeri incredibili di Xiaomi: nel 2025...
In Cina è pronto il parco fotovol...
Neuralink accelera: produzione di massa ...
Starlink abbassa l'orbita di migliaia di...
Dal MIT una nuova batteria per auto elet...
Adam Mosseri parla di IA su Instagram: l...
Suonerie personalizzate e Tone Store: il...
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:35.


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