Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Lenovo ThinkPad X1 2-in-1 G10 Aura Edition: il convertibile di classe
Lenovo ThinkPad X1 2-in-1 G10 Aura Edition: il convertibile di classe
La flessibilità di configurazione è il punto di forza di questo 2-in-1, che ripropone in un form factor alternativo tutta la tipica qualità dei prodotti Lenovo della famiglia ThinkPad. Qualità costruttiva ai vertici, ottima dotazione hardware ma costo che si presenta molto elevato.
Intervista a Stop Killing Games: distruggere videogiochi è come bruciare la musica di Mozart
Intervista a Stop Killing Games: distruggere videogiochi è come bruciare la musica di Mozart
Mentre Ubisoft vorrebbe chiedere agli utenti, all'occorrenza, di distruggere perfino le copie fisiche dei propri giochi, il movimento Stop Killing Games si sta battendo per preservare quella che l'Unione Europea ha già riconosciuto come una forma d'arte. Abbiamo avuto modo di parlare con Daniel Ondruska, portavoce dell'Iniziativa Europa volta a preservare la conservazione dei videogiochi
Samsung Galaxy S25 Edge: il top di gamma ultrasottile e leggerissimo. La recensione
Samsung Galaxy S25 Edge: il top di gamma ultrasottile e leggerissimo. La recensione
Abbiamo provato il nuovo Galaxy S25 Edge, uno smartphone unico per il suo spessore di soli 5,8 mm e un peso super piuma. Parliamo di un device che ha pro e contro, ma sicuramente si differenzia dalla massa per la sua portabilità, ma non senza qualche compromesso. Ecco la nostra prova completa.
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 12-07-2007, 09:34   #1
lucas87
Bannato
 
Iscritto dal: Oct 2006
Messaggi: 170
3 Esercizi in C

Salve dovevo fare 3 esercizi in C per un compito, ed ho preso 12/30 ora vi dico gli esercizi e come gli ho fatti, spero che qualcuno mi possa aiutare facendomi capire dove ho sbagliato.


1-Abbiamo un vettore in cui sono presenti numeri interi. La funzione doveva restituire il rango del vettore, ovvero il numeri di elementi che aveva la sequenza strettamente crescente più lunga.

esempio: 12323456 rango=5
Codice HTML:
int rango(int a[],int dim){
    int r=1;aux_r=1,i;
    for (i=0;i<dim;i++){
         if (a[i]<a[i+1]) aux_r++;
            else if (aux_r>r) { r=aux_r;
                                     aux_r=1;
                                   }
    }if (aux_r>r) r=aux_r 
return r;
}

2-un numero n è crescente se ogni cifre è maggiore o uguale della successiva. creare una funzione ricorsiva per sapere se un numero n è crescente. n passato alla funzione sara >=1;

esempio: n=43321 crescente=1;

Codice HTML:
int crescente(int n){
int n_uno,n_due;
     if(n==0) return 1;
      else{
             n_uno=n/10;
             n=n%10;
             n_due=n/10;
 
             if (n_uno<n_due) return 0;
                else return crescente(n);
}
}

3- questo è complicato da spiegare. allora avevamo un grafico di una linea spezzata, ogni punto aveva le cordinate x,y e le cordinate erano presenti in una lista.
ps: le corsinate sono gia ordinate crescentemente.

dato in input due cordinate x,y bisognava sostituirle alle cordinate della lista che ci si avvicinavano di più. nel caso in cui 2 cordinate nella lista erano = si sostituivano alle prime che si incontravano nella lista.
avevamo una funzione distanza che passate due coppie di cordinate ci diceva gia la distanza, che non dovevamo implementare.

io l'ho risolto cosi, pero penso che sia sbagliato e stamattina invece l'ho pensato in un altro modo, posto tutti e due i modi:

1- la struttura aveva un puntatore a next e uno a prec;

Codice HTML:
list correggi(list l,int x,int y){
     if(l==NULL) return NULL;
       else{
               if (dist(l->prec->x,l->prec,y,x,y)>dist(l->x,l->y,x,y) &&
                   dist(l->x,l->y,x,y)<dist(l->next->x,l->next->y,x,y)) {scambio;
                                                                                           return l;
                                                                                          }
}correggi(l->next,x,y);
}
2-modo piu semplice che ho pensato stamattina, pensando che la lista è ordinata crescentemente si faceva ammeno del puntatore a prec.

Codice HTML:
list correggi(list l,int x,int y){
     if(l==NULL) return NULL;
       else{
               if (dist(l->x,l->,y,x,y)<dist(l->next->x,l->next->y,x,y) {scambia;
                                                                                          return l;
                                                                                         }
      }correggi(l->next,x,y);
}

allora le soluzioni sono scritte direttamente nei tag xke non ho C in questo momento.

Comunque credo che il primo funzionasse quando lo provai su C, il secondo usciva sempre, e il terzo non l'ho provato.

Aiutatemi a capire dove ho sbagliato.

Grazie
lucas87 è offline   Rispondi citando il messaggio o parte di esso
Old 12-07-2007, 09:53   #2
lucas87
Bannato
 
Iscritto dal: Oct 2006
Messaggi: 170
Mi rispondod a solo intanto, il primo esercvizio funge, solo c'è un caso limite, se c'è un solo elemento nel vettore mida sequenza 2,quindi basta mettere
if(dim==1) return 1; prima del for nella funzione e va tutto apposto.
lucas87 è offline   Rispondi citando il messaggio o parte di esso
Old 12-07-2007, 09:57   #3
lucas87
Bannato
 
Iscritto dal: Oct 2006
Messaggi: 170
E' chiaro che il secondo cosi non funzionerà mai perche se n/10 non mi da la prima cifra di n, come avevo pensato io. Chi mi aiuta a capire come si doveva fare??

Grazie
lucas87 è offline   Rispondi citando il messaggio o parte di esso
Old 12-07-2007, 10:09   #4
lucas87
Bannato
 
Iscritto dal: Oct 2006
Messaggi: 170
Ok, ecco come doveva essere il secondo

Codice HTML:
int crescente(int n){
    int n1,n2;
    if(n<10) return 1;
    else{
         n1=n%10;
         n=n/10;
         n2=n%10;
         if (n1>n2) return 0;
            else return crescente(n);
            }
            }
mi avrà contato quanche punto al primo xke avevo sbagliato a calcolare un caso limite, qualche punto al secondo facilmente modificabile e probabilmente ho completamente sbagliato il terzo. Chi mi fa capire come doveva esssere fatto il terzo?
lucas87 è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Lenovo ThinkPad X1 2-in-1 G10 Aura Edition: il convertibile di classe Lenovo ThinkPad X1 2-in-1 G10 Aura Edition: il c...
Intervista a Stop Killing Games: distruggere videogiochi è come bruciare la musica di Mozart Intervista a Stop Killing Games: distruggere vid...
Samsung Galaxy S25 Edge: il top di gamma ultrasottile e leggerissimo. La recensione Samsung Galaxy S25 Edge: il top di gamma ultraso...
HP Elitebook Ultra G1i 14 è il notebook compatto, potente e robusto HP Elitebook Ultra G1i 14 è il notebook c...
Microsoft Surface Pro 12 è il 2 in 1 più compatto e silenzioso Microsoft Surface Pro 12 è il 2 in 1 pi&u...
Star Wars Outlaws 2 cancellato: per Ubis...
F1 senza freni: il film supera i 500 mil...
Una supersportiva elettrica da 429 CV a ...
Denodo DeepQuery: ricerche complesse in ...
Pluribus è la nuova ambiziosa ser...
IA come persone: avranno una personalit&...
Scoppia la bufera NSFW: la mano di Colle...
Philips porta OneBlade su Fortnite: arri...
Il consumo dei data center AI esplode: r...
Dimenticate tutto quello che avete visto...
Prodotti illegali su Temu: l'UE avvia pr...
La Cina vuole una governance globale del...
Aperta la CALL4INNOVIT 2025: al centro r...
ECOVACS DEEBOT T50 OMNI è recente...
Torvalds rilascia Linux 6.16, le novit&a...
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: 16:34.


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