Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Sony WF-1000X M6: le cuffie in-ear di riferimento migliorano ancora
Sony WF-1000X M6: le cuffie in-ear di riferimento migliorano ancora
WF-1000X M6 è la sesta generazione di auricolare in-ear sviluppata da Sony, un prodotto che punta a coniugare facilità di utilizzo con una elevata qualità di riproduzione dei contenuti audio e una cura nella riduzione del rumore ambientale che sia da riferimento
Snowflake porta l'IA dove sono i dati, anche grazie a un accordo con OpenAI
Snowflake porta l'IA dove sono i dati, anche grazie a un accordo con OpenAI
Snowflake ha presentato diverse novità per la sua piattaforma legate all'intelligenza artificiale. Quella forse più eclatante è una collaborazione con OpenAI, ma non mancano diverse nuove funzionalità che rendono la piattaforma più flessibile e in grado di rispondere meglio alle esigenze in continuo cambiamento delle aziende
Sistema Mesh Roamii BE Pro: il Wi-Fi 7 secondo MSI
Sistema Mesh Roamii BE Pro: il Wi-Fi 7 secondo MSI
Con velocità teoriche fino a 11 Gbps, gestione tramite app intelligente e protezione avanzata dei dispositivi, Roamii BE Pro porta il Wi‑Fi 7 tri‑band nelle abitazioni più esigenti. Un sistema Wi-Fi Mesh proposto da MSI allo scopo di garantire agli utenti una rete fluida e continua capace di sostenere streaming 8K, gaming competitivo e le applicazioni moderne più esigenti in termini di banda
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 12-07-2007, 10: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, 10: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, 10: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, 11: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


Sony WF-1000X M6: le cuffie in-ear di riferimento migliorano ancora Sony WF-1000X M6: le cuffie in-ear di riferiment...
Snowflake porta l'IA dove sono i dati, anche grazie a un accordo con OpenAI Snowflake porta l'IA dove sono i dati, anche gra...
Sistema Mesh Roamii BE Pro: il Wi-Fi 7 secondo MSI Sistema Mesh Roamii BE Pro: il Wi-Fi 7 secondo M...
Recensione HUAWEI Mate X7: un foldable ottimo, ma restano i soliti problemi Recensione HUAWEI Mate X7: un foldable ottimo, m...
Nioh 3: souls-like punitivo e Action RPG Nioh 3: souls-like punitivo e Action RPG
Unity Technologies punta sull'AI generat...
Keenadu, nuovo malware Android: Kaspersk...
MSI GeForce RTX 5090 Lightning Z a 2500 ...
Call of Duty: Warzone Mobile chiuder&agr...
Portatile tuttofare HP Ryzen 7, 16GB RAM...
LEFANT M3Max è uno dei robot pi&u...
Addio muffa e umidità: deumidific...
Apple TV in arrivo su CarPlay? Il codice...
TSMC pronta ad annunciare quattro nuove ...
Alla ricerca di un drone professionale a...
Stop agli assistenti AI integrati su tab...
iPhone 18 Pro e Pro Max: addio alle SIM ...
Samsung Galaxy S26: l'Exynos 2600 &egrav...
PS6 in forte ritardo e Switch 2 pi&ugrav...
Nuova rimodulazione da TIM: fino a 5 eur...
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:35.


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