Torna indietro   Hardware Upgrade Forum > Software > Programmazione

HONOR Magic 8 Pro: ecco il primo TOP del 2026! La recensione
HONOR Magic 8 Pro: ecco il primo TOP del 2026! La recensione
HONOR ha finalmente lanciato il suo nuovo flagship: Magic 8 Pro. Lo abbiamo provato a fondo in queste settimane e ve lo raccontiamo nella nostra recensione completa. HONOR rimane fedele alle linee della versione precedente, aggiungendo però un nuovo tasto dedicato all'AI. Ma è al suo interno che c'è la vera rivoluzione grazie al nuovo Snapdragon 8 Elite Gen 5 e alla nuova MagicOS 10
Insta360 Link 2 Pro e 2C Pro: le webcam 4K che ti seguono, anche con gimbal integrata
Insta360 Link 2 Pro e 2C Pro: le webcam 4K che ti seguono, anche con gimbal integrata
Le webcam Insta360 Link 2 Pro e Link 2C Pro sono una proposta di fascia alta per chi cerca qualità 4K e tracciamento automatico del soggetto senza ricorrere a configurazioni complesse. Entrambi i modelli condividono sensore, ottiche e funzionalità audio avanzate, differenziandosi per il sistema di tracciamento: gimbal a due assi sul modello Link 2 Pro, soluzione digitale sul 2C Pro
Motorola edge 70: lo smartphone ultrasottile che non rinuncia a batteria e concretezza
Motorola edge 70: lo smartphone ultrasottile che non rinuncia a batteria e concretezza
Motorola edge 70 porta il concetto di smartphone ultrasottile su un terreno più concreto e accessibile: abbina uno spessore sotto i 6 mm a una batteria di capacità relativamente elevata, un display pOLED da 6,7 pollici e un comparto fotografico triplo da 50 MP. Non punta ai record di potenza, ma si configura come alternativa più pragmatica rispetto ai modelli sottili più costosi di Samsung e Apple
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 18-02-2005, 11:26   #1
3nigma666
Senior Member
 
L'Avatar di 3nigma666
 
Iscritto dal: Jan 2005
Città: A casa mia
Messaggi: 825
[C++] Calcolare il tempo di esecuzione Della CPU in algoritmo QuickSort

salve a tutti ho un problema.
In c++ ho implementato il codice dell'algoritmo di ordinamento divettori QuickSort,il quale risulta molto efficente essendo la sua complessita pari a n(logn) quando altri algoritmi hanno complessita'n^2 ecc.
L'algoritmo in se funziona perfettamente,il problema è ke nn riesko a calcolare ltempo di esecuzione con la funzione clock() inclusa nella libreria time.h,mi da come risultato 0 ms,il ke è impossibile aveno effettuato circa 500000 ripetizioni dell algoritmo con 1 vettore lungo 5000 elementi
vi allego il codice qua sotto,spero ke l identazione del forum nn faccia pasticci e sia comprensibile il tutto

CODICE:


//----------------------------------------------------------------------------------
// Università agli studi di Udine
// Anno Accademico : 2004/2005
// Studente : Valerio Bignardi
// Name : QuickSort
// Desc : Funzione ke prende in input un vettore di lunghezza definita da MAX,
// dove ogni elemento del vettore è generato casualmente dalla funzione Random
// il programma prende un elemento a caso nel vettore definito come pivot e divide
// ricorsivamente il vettore in 2 parti ,dove a sx ci sono tutti gli elementi inferiori
// di pivot e a dx tutti gli elementi maggiori di pivot.
// ci sono 2 puntatori uno all'inizio del vettore e uno alla fine ke scorrono verso il
// pivot tutto il vettore.
// Quando il programma trova un elemento inferiore a pivot nella parte dx o
// viceversa un elemento maggiore a sx,inverte i 2 vettori,posizionando cosi tutti gli
// elementi.
// QuickSort di divide essenzialmente in 2 funzioni:
// -Partition ke assegna un pivot e scandisce il vettore
// -Swap ke inverte due elementi da ordinare
// -QuickSort ke richiama ricorsivamente se stesso passando a se stesso prima l'albero sx
// e poi l'albero dx
// Vers : 0.99
// ToDo : Implementare il calcolo del tempo di esecuione tramite la funzione clock() e
// immettere un numero di ripetizione tali ke l'esecuzione del programma sia maggiore
// dell'orologio di sistema
// Bugs : Implementare il codice relativo al calcolo del tempo
//----------------------------------------------------------------------------------

#include <iostream>
#include <stdio.h>
#include <time.h>
#include <math.h>


//DICHIARAZIONE DELLE COSTANTI

#define A 16087
#define M 2147483647
#define Q 127773
#define R 2836

//DICHIARAZIONE DELLE VARIABILI E INIZIALIZZAZIONE

const int max = 500000; // Dichiaro la costante intera max inizializzata a 10000
int j = 0;
int q = 0;
int pivot = 0;
int i = 0;
long vettore [max];// Dichiaro un array di nome vettore, di dimensione max.
double seed; //Variabile globale ke contiene il seme della funzione random


//------------------------------------------
// Name : Random()
// Desc : funzione Random() che restituisce un numero casuale compreso tra 0 e 1
// ToDo : Nulla
//------------------------------------------

double Random()
{
double lo, hi, test;

hi = ceil(seed / Q);
lo = seed - Q * hi;
test = A * lo - R * hi;
if (test < 0.0) {
seed = test + M;
} else {
seed = test;
} /* endif */
return seed / M;
} //end random



//------------------------------------------------------------------------
// Name : swap(long& a, long& b)
// Desc : Questa funzione implementa lo scambio dei valori con
// la tecnica inplace, ovverosia senza alcuna variabile di supporto
// Si noti che i parametri sono passati per riferimento, altrimenti
// le modifiche sarebbero effettuate su copie di essi, e lo scambio di valore non ci sarebbe.
// ToDo : Nulla
// Vers : 1.0
//--------------------------------------------------------------------------

void swap (long& a, long& b) {
a = b + a; // (a+b) b
b = a - b; // (a+b) (a+b)-b
a = a - b; // (a+b)-a a
};

//-------------------------------------------------------
// Name : Partition
// Desc : Prende come parametri puntatore ad un vettore, indice sinistro ,indice destro
// Inizia a scorrerre il vettore partendo da fuori il vettore
// e inizia un loop ke continua fino a quando l'indice sx è minore dell'indice dx
// Dentro al loop viene fatto scorrere il vettore e ogni singolo elemento del vettore
// viene confrontato con il pivot e se maggiore viene messo a dx se inferiore viene
// posizionato a sx tramite la funzione swap
// ToDo : Nulla
// Vers : 0.9
// Bugs : N.P.
//--------------------------------------------------------

int Partition (long* vett,int left,int right){
pivot = vett[left];//a pivot assegno il primo elemento
i = left - 1 ; //inizio da fuori il vettore
j = right + 1; //inizio da fuori il vettore
//fino a quando l indice inferiore non supera l indice superiore continua a cercare gli elementi
while (i < j){
do{j--;} //decrementa di una posizione l'indice superiore
while (vett[j]>pivot); //continua a decrementare fino a quando l elemento trovato nn è maggiore del pivot
do{ i++;}
while (vett[i]<pivot);//continua a decrementare fino a quando l elemento trovato nn è minore del pivot
if (i<j)
swap(vett[i],vett[j]);//inverti i due valori
else
return j;// se i ha superato j ritorno il nuovo pivot a Qsort
}//end while
}//end partition




//-------------------------------------------------------------
// Name : QuickSort
// Desc : Assegna un valore a al pivot q.la funzione richiama se stessa
// ricorsivamente passandosi prima l'albero di dx e poi quello di sx
// ToDO : Nulla
// Vers : 1.0
// Bugs : N.P
//-----------------------------------------------------------



void QuickSort (long* vett,int left,int right){
if (left < right){
q = Partition (vett,left,right); //Assegnazione pivot
QuickSort(vett,left,q);//albero di sinistra
QuickSort(vett,q+1,right);//albero di destra
}//end if
}//end quicksort


// Programma principale

int main () {

seed = 123456789; //inizializzazione seme
//---------Creo il vettore----------
for (int i=0; i<=max;i++)
vettore[i] =(long)( Random()*500000);


// --- Richiamo la funzione QuickSort
// --- Implemento il calcolo temporale di esecuzione dell'algoritmo QuickSort
// Per eseguire tale operazione devo a priori calcolare la precisione dell'orologio
// di sistema,per fare cio' basta implementare questo codice:
/*int main()
{
float t0 = clock();
float t1 = clock();
while (t0 == t1)
t1 = clock();
float tot = (t1 - t0)/CLOCKS_PER_SEC;
return 0;
}*/
// il valore risultante è 15 ms. di conseguenza il tempo minimo misurabile con
// errore massimo del 5% è dato da:
// errore tollerato : 100 = precisione orologio : minimo tempo misurab. x
// quindi x = (100 * precisione orologio) / 5%
// ke nel nostro caso è: (100 * 15) / 5 quindi x = 300 ms

float t0 = clock();
for (int y=0;y==5000000;y++)
QuickSort(vettore,0,(max - 1));
float t1 = clock();
float tot = (t1-t0)/CLOCKS_PER_SEC;
/* //--Stampo il vettore ordinato per controllo
for (int i = 0; i < max; i++)
std::cout << vettore[i] << std::endl; //stampo a schermo*/
// Aspetto input da tastiera prima di chiudere la shell ( per evitare chiusura immediata sotto Win)
std::cout<<tot;
int n = 0;
std::cin>>n;
//exit with code 0
return 0;
}//end mainAllego il link del mio ftp dal quale poter scaricare il codice sorgente se dal forum risulta di difficile comprensione

ftp://hwupgrade:[email protected]

Grazie a tutti coloro ke mi daranno una mano

3NiGm@666

PS: Se si usa browser FTP entrare in attive mode ,disabilitare il passive mode perke sono dietro a router
3nigma666 è offline   Rispondi citando il messaggio o parte di esso
Old 18-02-2005, 12:25   #2
ilsensine
Senior Member
 
L'Avatar di ilsensine
 
Iscritto dal: Apr 2000
Città: Roma
Messaggi: 15625
Codice:
for (int y=0;y==5000000;y++)
La condizione y==5000000 è sempre falsa, quindi il ciclo for non viene eseguito neanche una volta.
__________________
0: or %edi, %ecx; adc %eax, (%edx); popf; je 0b-22; pop %ebx; fadds 0x56(%ecx); lds 0x56(%ebx), %esp; mov %al, %al
andeqs pc, r1, #147456; blpl 0xff8dd280; ldrgtb r4, [r6, #-472]; addgt r5, r8, r3, ror #12
ilsensine è offline   Rispondi citando il messaggio o parte di esso
Old 18-02-2005, 13:06   #3
3nigma666
Senior Member
 
L'Avatar di 3nigma666
 
Iscritto dal: Jan 2005
Città: A casa mia
Messaggi: 825
ma scusa nn dovrebbe essere un semplicissimo for ke va da 0 a 500.000 ripetizioni??
3nigma666 è offline   Rispondi citando il messaggio o parte di esso
Old 18-02-2005, 13:34   #4
ilsensine
Senior Member
 
L'Avatar di ilsensine
 
Iscritto dal: Apr 2000
Città: Roma
Messaggi: 15625
No è un semplicissimo for che non viene eseguito neanche una volta
Forse volevi scrivere
for (int y=0;y<5000000;y++)
__________________
0: or %edi, %ecx; adc %eax, (%edx); popf; je 0b-22; pop %ebx; fadds 0x56(%ecx); lds 0x56(%ebx), %esp; mov %al, %al
andeqs pc, r1, #147456; blpl 0xff8dd280; ldrgtb r4, [r6, #-472]; addgt r5, r8, r3, ror #12
ilsensine è offline   Rispondi citando il messaggio o parte di esso
Old 18-02-2005, 13:57   #5
3nigma666
Senior Member
 
L'Avatar di 3nigma666
 
Iscritto dal: Jan 2005
Città: A casa mia
Messaggi: 825
ke idiota ke sono ... grazie mille ..nel frattempo per ovviare avevo fatto un do{
}while (n<500000)

grazie mille
3nigma666 è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


HONOR Magic 8 Pro: ecco il primo TOP del 2026! La recensione HONOR Magic 8 Pro: ecco il primo TOP del 2026! L...
Insta360 Link 2 Pro e 2C Pro: le webcam 4K che ti seguono, anche con gimbal integrata Insta360 Link 2 Pro e 2C Pro: le webcam 4K che t...
Motorola edge 70: lo smartphone ultrasottile che non rinuncia a batteria e concretezza Motorola edge 70: lo smartphone ultrasottile che...
Display, mini PC, periferiche e networking: le novità ASUS al CES 2026 Display, mini PC, periferiche e networking: le n...
Le novità ASUS per il 2026 nel settore dei PC desktop Le novità ASUS per il 2026 nel settore de...
MaiaSpace ed Eutelsat stringono un accor...
Motorola edge 60 neo sorprende: compatto...
Zeekr 007 e 007GT si aggiornano: piattaf...
ASUS ROG Swift OLED PG27AQWP-W: 720 Hz e...
È super il prezzo del robot rasae...
MediaTek aggiorna la gamma di Dimensity:...
Foto intime sottratte dai telefoni in ri...
In Cina approvate nuove regole per il ri...
L'accordo multi-miliardario tra Google e...
Alcuni PC Windows 11 non si spengono dop...
Apple sta per lanciare un nuovo monitor:...
Mondraker Crafty Unlimited Gulf Edition,...
Amazon, altro rilancio per Haul: sconto ...
Chiusi in un bunker per soldi: Fallout d...
Yakuza Kiwami 3 and Dark Ties avrà...
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: 17:44.


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