Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Test ride con Gowow Ori: elettrico e off-road vanno incredibilmente d'accordo
Test ride con Gowow Ori: elettrico e off-road vanno incredibilmente d'accordo
Abbiamo provato per diversi giorni una new entry del mercato italiano, la Gowow Ori, una moto elettrica da off-road, omologata anche per la strada, che sfrutta una pendrive USB per cambiare radicalmente le sue prestazioni
Recensione OnePlus 15: potenza da vendere e batteria enorme dentro un nuovo design
Recensione OnePlus 15: potenza da vendere e batteria enorme dentro un nuovo design
OnePlus 15 nasce per alzare l'asticella delle prestazioni e del gaming mobile. Ma non solo, visto che integra un display LTPO 1,5K a 165 Hz, OxygenOS 16 con funzioni AI integrate e un comparto foto con tre moduli da 50 MP al posteriore. La batteria da 7.300 mAh con SUPERVOOC 120 W e AIRVOOC 50 W è la ciliegina sulla torta per uno smartphone che promette di offrire un'esperienza d'uso senza alcun compromesso
AMD Ryzen 5 7500X3D: la nuova CPU da gaming con 3D V-Cache per la fascia media
AMD Ryzen 5 7500X3D: la nuova CPU da gaming con 3D V-Cache per la fascia media
Vediamo come si comporta il Ryzen 5 7500X3D, nuovo processore di casa AMD che fonde 6 core Zen 4 con la tecnologia 3D V-Cache, particolarmente utile in scenari come il gaming. Annunciato a un prezzo di listino di 279€, il nuovo arrivato sarà in grado di diventare un riferimento per i sistemi budget? Ecco cosa ne pensiamo.
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 01-04-2011, 19:30   #1
EnergyVortex
Member
 
Iscritto dal: Aug 2009
Messaggi: 287
[C/C++] Calcolo complessità algoritmo

Ciao a tutti, devo calcolare la complessità di tre algoritmi che ci hanno chiesto di implementare però non so bene come calcolarla.
So che un'operazione di assegnamento vale 1 ma già al primo if mi blocco perchè non so che valore dargli.
Vi posto una delle funzioni giusto per farvi un'idea:

void cambia_gravita(struct paziente A[],int N)

{

if (N==0)

{

printf("\nNessun paziente in coda!!\n");

return;

}

int k,G,matr;

G=0;

printf("Inserire la matricola del paziente a cui si vuole cambiare codice gravita:");

scanf("%d",&matr);

for (k=0;k<N;k++)

if (A[k].matricola==matr)

{

while (G<1 || G>4)

{

printf("\n Inserire nuovo codice gravita:");

scanf("%d",&G);

}

A[k].priorita=G*1000+matr;

HeapSort(A);

printf("Codice gravità cambiato \n");

G=0;

return;

}

printf("Numero di matricola non trovato! \n");

return;

}


Ho provato a cercare in rete ma non ho trovato nulla di comprensibile.
Confido in voi.
Ciao e grazie
EnergyVortex è offline   Rispondi citando il messaggio o parte di esso
Old 02-04-2011, 10:23   #2
goldorak
Senior Member
 
Iscritto dal: Apr 2003
Messaggi: 16462
Quote:
Originariamente inviato da EnergyVortex Guarda i messaggi
Ciao a tutti, devo calcolare la complessità di tre algoritmi che ci hanno chiesto di implementare però non so bene come calcolarla.
So che un'operazione di assegnamento vale 1 ma già al primo if mi blocco perchè non so che valore dargli.
Dipende dal modello di calcolo che usi. In genere si assume che il costo (di tempo) di ogni istruzione elementare sia 1 (per l'istruzione di assegnamento).
Per l'if la complessita' e' il massimo tra la complessita' del blocco che viene eseguito se la condizione e' vera e quella del blocco che viene eseguito se la condizione e' falsa.
Per i cicli definiti (while, for,...) il costo e' semplicemente la somma sulle diverse iterazioni del costo delle istruzioni a cui il ciclo si riferisce.

Ad esempio per i cicli in pseudocodice (un esempio semplice semplice):

Codice:
 for i = 1 to n do
   for j= i to m do
    a[i,j]=0
Che complessita' ha ?
  • il ciclo piu' esterno viene eseguito n volte quindi parti con Σ(i=1, n)(costo del blocco indentato).
  • il ciclo piu' interno viene eseguito m-i+1 volte quindi parti con Σ(j=i, m)(costo del assegnamento).
  • l'assegnamento vale 1 quindi il costo totale e'
  • Σ(i=1,n) Σ(j=i,m) (1)
  • la sommatoria piu' interna vale m-i+1
  • quindi ottieni Σ(i=1,n) (m-i+1)
  • semplificando viene m* (Σ(i=1,n) 1) - Σ(i=1,n) i + Σ(i=1,n) 1
  • il primo termine e' n*m, il secondo e' -n(n+1)/2 ed il terzo e' n
  • quindi la complessita' totale e' nm-n(n+1)/2-n
__________________
MICROSOFT : Violating your privacy is our priority
goldorak è offline   Rispondi citando il messaggio o parte di esso
Old 04-04-2011, 22:09   #3
EnergyVortex
Member
 
Iscritto dal: Aug 2009
Messaggi: 287
Ho fatto come mi hai detto, speriamo bene!
grazie per l'aiuto!
EnergyVortex è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Test ride con Gowow Ori: elettrico e off-road vanno incredibilmente d'accordo Test ride con Gowow Ori: elettrico e off-road va...
Recensione OnePlus 15: potenza da vendere e batteria enorme dentro un nuovo design   Recensione OnePlus 15: potenza da vendere e batt...
AMD Ryzen 5 7500X3D: la nuova CPU da gaming con 3D V-Cache per la fascia media AMD Ryzen 5 7500X3D: la nuova CPU da gaming con ...
SONY BRAVIA 8 II e BRAVIA Theatre System 6: il cinema a casa in formato compatto SONY BRAVIA 8 II e BRAVIA Theatre System 6: il c...
KTC H27E6 a 300Hz e 1ms: come i rivali ma a metà prezzo KTC H27E6 a 300Hz e 1ms: come i rivali ma a met&...
Mai così tanti gas serra: il 2025...
Google condannata in Germania: favorito ...
Ubisoft rimanda i risultati finanziari e...
ADATA porta i primi moduli DDR5 CUDIMM 4...
Bob Iger anticipa le novità AI di...
Microsoft Teams 'spierà' i dipend...
Michael Burry chiude Scion e fa di nuovo...
Huawei prepara i nuovi Mate 80: fino a 2...
Una e-Mountain Bike di qualità ma...
Tutte le offerte Amazon Black Friday pi&...
DJI Mini 4K Fly More Combo con 3 batteri...
Crollo di prezzo sui nuovissimi iPhone A...
Uno smartphone super economico ma potent...
Offerte Black Friday: PlayStation 5 ora ...
Samsung alza i listini fino al 60%: sta ...
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:01.


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