Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Sony INZONE H6 Air: il primo headset open-back di Sony per giocatori
Sony INZONE H6 Air: il primo headset open-back di Sony per giocatori
Il primo headset open-back della linea INZONE arriva a 200 euro con driver derivati dalle cuffie da studio MDR-MV1 e un peso record di soli 199 grammi
Nutanix cambia pelle: dall’iperconvergenza alla piattaforma full stack per cloud ibrido e IA
Nutanix cambia pelle: dall’iperconvergenza alla piattaforma full stack per cloud ibrido e IA
Al .NEXT 2026 di Chicago, Nutanix ha mostrato quanto sia cambiata: una piattaforma software che gestisce VM, container e carichi di lavoro IA ovunque, dall’on-premise al cloud pubblico. Con un’esecuzione rapidissima sulle partnership e sulla migrazione da VMware
Recensione Xiaomi Pad 8 Pro: potenza bruta e HyperOS 3 per sfidare la fascia alta
Recensione Xiaomi Pad 8 Pro: potenza bruta e HyperOS 3 per sfidare la fascia alta
Xiaomi Pad 8 Pro adotta il potente Snapdragon 8 Elite all'interno di un corpo con spessore di soli 5,75 mm e pannello LCD a 144Hz flicker-free, per un tablet che può essere utilizzato con accessori dedicati di altissima qualità. Fra le caratteristiche esclusive, soprattutto per chi intende usarlo con la tastiera ufficiale, c'è la modalità Workstation di HyperOS 3, che trasforma Android in un sistema operativo con interfaccia a finestre
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 01-04-2011, 18: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, 09: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, 21: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


Sony INZONE H6 Air: il primo headset open-back di Sony per giocatori Sony INZONE H6 Air: il primo headset open-back d...
Nutanix cambia pelle: dall’iperconvergenza alla piattaforma full stack per cloud ibrido e IA Nutanix cambia pelle: dall’iperconvergenza alla ...
Recensione Xiaomi Pad 8 Pro: potenza bruta e HyperOS 3 per sfidare la fascia alta Recensione Xiaomi Pad 8 Pro: potenza bruta e Hyp...
NZXT H9 Flow RGB+, Kraken Elite 420 e F140X: abbiamo provato il tris d'assi di NZXT NZXT H9 Flow RGB+, Kraken Elite 420 e F140X: abb...
ASUS ROG Swift OLED PG34WCDN recensione: il primo QD-OLED RGB da 360 Hz ASUS ROG Swift OLED PG34WCDN recensione: il prim...
Rockstar Games guadagna ancora cifre eno...
Nasce DIVE - Driving Innovation in Venet...
Fastweb entra tra i partner di Starlink ...
Tesla completa il tape-out del chip AI5:...
App falsa di Ledger Live sull'App Store ...
Svelato il prezzo dell'e-bike che sostit...
ASML vola grazie all'AI: numeri oltre le...
Google lancia l'app nativa per Windows: ...
'Non dovremmo lasciarli entrare nel nost...
Windows 11 25H2 e 24H2, build 26200.8246...
Windows 10, il nuovo aggiornamento estes...
Microsoft potrebbe tornare a puntare sul...
Undervolt con un clic: NV-UV ottimizza l...
L'Italia finanzia CamGraPhIC (2D Photoni...
Google Chrome introduce le Skills, per 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: 11:05.


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