Torna indietro   Hardware Upgrade Forum > Software > Programmazione

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: abbiamo provato il tris d'assi di NZXT
Nelle ultime settimane abbiamo provato tre delle proposte top di gamma di NZXT nelle categorie case, dissipatori e ventole. Rispettivamente, parliamo dell'H9 Flow RGB+, Kraken Elite 420 e F140X. Si tratta, chiaramente, di prodotti di fascia alta che si rivolgono agli utenti DIY che desiderano il massimo per la propria build. Tuttavia, mentre i primi due dispositivi mantengono questa direzione, le ventole purtroppo hanno mostrato qualche tallone d'Achille di troppo
ASUS ROG Swift OLED PG34WCDN recensione: il primo QD-OLED RGB da 360 Hz
ASUS ROG Swift OLED PG34WCDN recensione: il primo QD-OLED RGB da 360 Hz
ASUS ROG Swift OLED PG34WCDN è il primo monitor gaming con pannello QD-OLED Gen 5 a layout RGB Stripe Pixel e 360 Hz su 34 pollici: lo abbiamo misurato con sonde colorimetriche e NVIDIA LDAT. Ecco tutti i dati
Recensione Nothing Phone (4a) Pro: finalmente in alluminio, ma dal design sempre unico
Recensione Nothing Phone (4a) Pro: finalmente in alluminio, ma dal design sempre unico
Nothing Phone (4a) Pro cambia pelle: l'alluminio unibody sostituisce la trasparenza integrale, portando una solidità inedita. Sotto il cofano troviamo uno Snapdragon 7 Gen 4 che spinge forte, mentre il display è quasi da top dig amma. Con un teleobiettivo 3.5x e la Glyph Matrix evoluta, è la prova di maturità di Carl Pei. C'è qualche compromesso, ma a 499EUR la sostanza hardware e la sua unicità lo rendono un buon "flagship killer" in salsa 2026
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 27-05-2015, 18:05   #1
shiony710
Junior Member
 
Iscritto dal: Jan 2015
Messaggi: 16
[C] Complessità computazionale

Salve a tutti, avrei bisogno di un aiuto riguardante il calcolo della complessità computazionale, dato che dopo averlo studiato dal libro e da internet non ho comunque capito il modo per calcolarlo, quindi vi chiedo un aiuto utilizzando come esempio un codice che ho creato che devo portare all esame proprio con la sua complessità


Codice:
#include <stdio.h>
 
int main()
{
   int v[100], n, i, j, position, swap;
   
 
   printf("Inserisci il numero degli elementi\n");
   scanf("%d", &n);
 
   printf("Inserisci %d elementi\n", n);
 
   for ( i = 0 ; i < n ; i++ )
      scanf("%d", &v[i]);
 
   for ( i = 0 ; i < ( n - 1 ) ; i++ )
   {
      position = i;
 
      for ( j = i + 1 ; j < n ; j++ )
      {
         if ( v[position] < v[j] )
            position = j;
      }
      if ( position != i )
      {
         swap = v[i];
         v[i] = v[position];
         v[position] = swap;
      }
   }
 
   printf("Lista in ordine decrescente:\n");
 
   for ( i = 0 ; i < n ; i++ )
      printf("%d\n", v[i]);
    int x;
    printf("inserisci un intero x \n");		//Setto il valore di x
    scanf("%d", &x);
    for( i = 0; i < n; i++)
	{
	     if ( v[i] > x)
         {
  			 printf("Il primo elemento dell'array=%d e' maggiore di x=%d", v[i], x);
			 return 0;
		 }
		 int somma = 0;
			for(i = 0; i < n; i++)
			{
				somma += v[i];
				if (somma > x)
			    {
					printf("Vengono sommati gli elementi del vettore fino al v[%d],\nLa loro somma e' %d maggiore di x %d. ", i, somma, x);
					return 0;
			    }
			}
		 
	 
       printf("La somma di tutti gli elementi dell'array e' minore di x= %d\n",x);	
    }
	return 0;
   
}
shiony710 è offline   Rispondi citando il messaggio o parte di esso
Old 29-05-2015, 13:16   #2
wingman87
Senior Member
 
Iscritto dal: Nov 2005
Messaggi: 2789
Questo è il codice che hai scritto nell'altro thread?
E' ancora sbagliato: come ti dicevo dovresti dividere il codice in funzioni, sia per renderlo più leggibile sia perché la richiesta iniziale era di scrivere una funzione che restituisse la sequenza di elementi, non è sufficiente "rilevare" che esiste e stamparne la somma.

Detto questo, la complessità non si spiega in due righe, diciamo che in generale si possono dire un paio di cose, per capirne di più poi dovresti essere più specifico nelle tue domande:
- la complessità si esprime in relazione all'input dell'algoritmo
- la complessità può essere spaziale, cioè quanta memoria viene dedicata ai dati di supporto dell'algoritmo, o temporale, cioè quanto tempo impiega l'algoritmo a restituire l'output
- per calcolare la complessità di un algoritmo si segue il ragionamento che vi è alla base, in relazione a un input "generico" (caso medio). Può essere interessante anche calcolare la complessità del caso migliore con un input apposito che l'algoritmo risolve in un tempo minimo. Ad esempio se in input all'insertion sort dai un vettore già ordinato, esso ci impiegherà solo n passi, dove n è la dimensione del vettore di input. Il selection sort invece ci impiegherà sempre n^2 passi. D'altra parte anche il caso peggiore può essere interessante, sempre nel caso dell'insertion sort il caso peggiore è quando il vettore è ordinato al rovescio perché è necessario un numero maggiore di swap degli elementi, invece per il selection sort non cambia nulla perché il numero di swap è sempre n.
wingman87 è offline   Rispondi citando il messaggio o parte di esso
Old 29-05-2015, 13:43   #3
shiony710
Junior Member
 
Iscritto dal: Jan 2015
Messaggi: 16
Ora provvedo a sistemare il codice, comunque la mia richiesta riguarda la complessità riguardante il tempo ed il caso peggiore, dato che sono quelle che mi chiederanno. Vorrei sapere se è giusto dire che quest'algoritmo ha complessità O(n^2), e che è giusto dire che generalmente il selection sort ha per complessità O(n^2).
shiony710 è offline   Rispondi citando il messaggio o parte di esso
Old 29-05-2015, 14:54   #4
wingman87
Senior Member
 
Iscritto dal: Nov 2005
Messaggi: 2789
Se io fossi il professore ti chiederei perché ha complessità O(n^2) ed è lì che si capisce se hai capito come si calcola la complessità.
Inoltre se l'avessi scomposto in funzioni ti chiederei qual è la complessità delle singole funzioni.
Posso anche dirti di sì, che è corretto quello che dici, ma credo che ci farai poco all'esame.
Tra l'altro la seconda parte del tuo programma (che dovrebbe diventare una funzione) secondo te che complessità ha nel caso migliore? E nel peggiore? Si può fare di meglio, ragionaci su.
wingman87 è offline   Rispondi citando il messaggio o parte di esso
Old 29-05-2015, 15:09   #5
shiony710
Junior Member
 
Iscritto dal: Jan 2015
Messaggi: 16
La complessità è O(n^2), perché ci sono doppi cicli annidati se non sbaglio, comunque se non sbaglio la prima parte cioè quella dell'ordinamento dovrebbe essere O(n^2), mentre quello del confronto dovrebbe essere O(n).


P.S. Comunque infatti non voglio che mi dici solo se è giusto o sbagliato, perché so che non concluderei niente, a me interessa capire quindi ti ringrazio per l'aiuto che mi stai dando

Ultima modifica di shiony710 : 29-05-2015 alle 15:20.
shiony710 è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


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...
Recensione Nothing Phone (4a) Pro: finalmente in alluminio, ma dal design sempre unico Recensione Nothing Phone (4a) Pro: finalmente in...
WoW: Midnight, Blizzard mette il primo, storico mattone per l'housing e molto altro WoW: Midnight, Blizzard mette il primo, storico ...
Ecovacs Goat O1200 LiDAR Pro: la prova del robot tagliaerba con tagliabordi integrato Ecovacs Goat O1200 LiDAR Pro: la prova del robot...
Anthropic ha un'AI che trova falle in Wi...
I 10 migliori sconti Amazon del weekend:...
Con un coupon scendono ancora: le super ...
Minimo storico per Samsung Galaxy S26 Ul...
Si è conclusa la missione lunare ...
EK Waterblock si arrende agli aumenti, i...
Geekbench si aggiorna: tutti i test con ...
Per la prima volta un computer quantisti...
Telecamere Reolink 4K su Amazon: Wi-Fi 6...
Anthropic vuole farsi i chip da sola? Co...
Il fondatore di Framework: il personal c...
JBL Live Flex 3 a 129€ su Amazon: ANC ad...
Come un uomo ha costruito un'azienda da ...
Multe fino a 400 euro anche se hai pagat...
Tapo lancia una valanga di offerte su Am...
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:58.


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