Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Plaud NotePin S, il registratore IA si fa indossabile (ma è facile da perdere)
Plaud NotePin S, il registratore IA si fa indossabile (ma è facile da perdere)
Quattro modi di indossarlo, stessa app del Plaud Note Pro e integrazione con il desktop. Il registratore IA da indossare di Plaud eccelle in mobilità, ma resta vincolato all'abbonamento ed è facile da perdere
Redmi Watch 6 in prova: lo smartwatch con ampio display da 2000 nit a meno di 100 euro
Redmi Watch 6 in prova: lo smartwatch con ampio display da 2000 nit a meno di 100 euro
Xiaomi ha portato Redmi Watch 6 anche sul mercato italiano, puntando su un display AMOLED da 2,07 pollici con picco di luminosità a 2000 nit, frame in alluminio da 9,9mm e un'autonomia dichiarata di 12 giorni. Lo smartwatch gira su HyperOS 3 e integra GPS, Bluetooth 5.4 e oltre 150 sport mode. Il tutto a meno di 100 euro
Mad Catz M.M.O. 7+: lo stesso DNA del R.A.T. 8+ ADV, ma con molti più pulsanti
Mad Catz M.M.O. 7+: lo stesso DNA del R.A.T. 8+ ADV, ma con molti più pulsanti
Con 22 tasti, il pulsante 5D, lo Shift Mode e il sensore PixArt 3395 da 26.000 DPI, il nuovo mouse wireless di Mad Catz si rivolge in modo preciso ai giocatori di MMO e RPG. Ma chi conosce già il R.A.T. 8+ ADV si accorgerà subito di quanto i due prodotti condividano, e di dove invece divergono
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: 2790
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: 2790
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


Plaud NotePin S, il registratore IA si fa indossabile (ma è facile da perdere) Plaud NotePin S, il registratore IA si fa indoss...
Redmi Watch 6 in prova: lo smartwatch con ampio display da 2000 nit a meno di 100 euro Redmi Watch 6 in prova: lo smartwatch con ampio ...
Mad Catz M.M.O. 7+: lo stesso DNA del R.A.T. 8+ ADV, ma con molti più pulsanti Mad Catz M.M.O. 7+: lo stesso DNA del R.A.T. 8+ ...
Radeon RX 9070 GRE, AMD la porta in tutto il mondo | Recensione Gigabyte Gaming OC Radeon RX 9070 GRE, AMD la porta in tutto il mon...
Reolink OMVI 3i WiFi: videosorveglianza più intelligente e facile da usare Reolink OMVI 3i WiFi: videosorveglianza pi&ugrav...
Instagram Plus arriva in Italia: cosa in...
XBOX: la nuova CEO non ha ancora le idee...
Intel non ha intenzione di abbandonare i...
La AI Mode sarà attiva di default...
Marvel's Wolverine non sarà un op...
Star Wars Zero Company esce ad agosto: n...
Bonus Decoder: fino al 70% di sconto con...
Virtua Fighter è tornato e non &e...
Il ritorno di Fumito Ueda, autore di Sha...
Cooler Master svela GPU Shield, la nuova...
Samsung Galaxy S27 Pro: sarà lui ...
Così Google ha ottimizzato Chrome...
Xiaomi non cambia idea: il display poste...
LG presenta in Italia le gamme TV Micro ...
Sette anni dopo l'annuncio, The Wolf Amo...
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: 12:38.


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