Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Recensione Samsung Galaxy S26+: sfida l'Ultra, ma ha senso di esistere?
Recensione Samsung Galaxy S26+: sfida l'Ultra, ma ha senso di esistere?
Equilibrio e potenza definiscono il Samsung Galaxy S26+, un flagship che sfida la variante Ultra e la fascia alta del mercato con il primo processore mobile a 2nm. Pur mantenendo l'hardware fotografico precedente, lo smartphone brilla per un display QHD+ da 6,7 pollici d'eccellenza, privo però del trattamento antiriflesso dell'Ultra, e per prestazioni molto elevate. Completano il quadro la ricarica wireless a 20W e, soprattutto, un supporto software settennale
Zeekr X e 7X provate: prezzi, autonomia fino a 615 km e ricarica in 13 minuti
Zeekr X e 7X provate: prezzi, autonomia fino a 615 km e ricarica in 13 minuti
Zeekr sbarca ufficialmente in Italia con tre modelli elettrici premium, X, 7X e 001, distribuiti da Jameel Motors su una rete di 52 punti vendita già attivi. La Zeekr X parte da 39.900 euro, la 7X da 54.100: piattaforma a 800V, chip Snapdragon di ultima generazione, ricarica ultraveloce e un'autonomia dichiarata fino a 615 km WLTP. Le prime consegne sono previste a metà aprile
Marathon: arriva il Fortnite hardcore
Marathon: arriva il Fortnite hardcore
Marathon è il titolo multiplayer competitivo del momento. Ecco quali sono le caratteristiche di gioco principali, insieme alle nostre prime considerazioni dopo qualche "run" nell'extraction shooter di Bungie
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


Recensione Samsung Galaxy S26+: sfida l'Ultra, ma ha senso di esistere? Recensione Samsung Galaxy S26+: sfida l'Ultra, m...
Zeekr X e 7X provate: prezzi, autonomia fino a 615 km e ricarica in 13 minuti Zeekr X e 7X provate: prezzi, autonomia fino a 6...
Marathon: arriva il Fortnite hardcore Marathon: arriva il Fortnite hardcore
HP Imagine 2026: abbiamo visto HP IQ all’opera, ecco cosa può (e non può) fare HP Imagine 2026: abbiamo visto HP IQ all’opera, ...
PNY RTX 5080 Slim OC, sembra una Founders Edition ma non lo è PNY RTX 5080 Slim OC, sembra una Founders Editio...
Libri, penne e carta al posto dei tablet...
Nothing Phone (3a) Pro vs (3a): tutte le...
OkCupid e Match Group accusate dalla Fed...
Stellantis richiama 700.000 auto ibride ...
Proton lancia Meet: la nuova piattaforma...
Siri potrebbe avere uno store dedicato a...
Amazon, crollano i prezzi su robot aspir...
Amazon Haul lancia il -20% sulle offerte...
Apple aggiorna le liste di prodotti vint...
Tutti i dispositivi Amazon in offerta og...
Non solo smartphone, cuffie e orologi: N...
MacBook Air M4 2025 in offerta su Amazon...
Xiaomi porta HyperOS 3.1: rollout avviat...
Portatile HP super completo a 649€: 32GB...
OnePlus spoilera il nuovo Nord 6: il mid...
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: 10:40.


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