Torna indietro   Hardware Upgrade Forum > Software > Programmazione

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
Display, mini PC, periferiche e networking: le novità ASUS al CES 2026
Display, mini PC, periferiche e networking: le novità ASUS al CES 2026
Sono molte le novità che ASUS ha scelto di presentare al CES 2026 di Las Vegas, partendo da una gamma di soluzioni NUC con varie opzioni di processore passando sino agli schermi gaming con tecnologia OLED. Il tutto senza dimenticare le periferiche di input della gamma ROG e le soluzioni legate alla connettività domestica
Le novità ASUS per il 2026 nel settore dei PC desktop
Le novità ASUS per il 2026 nel settore dei PC desktop
Molte le novità anticipate da ASUS per il 2026 al CES di Las Vegas: da schede madri per processori AMD Ryzen top di gamma a chassis e ventole, passando per i kit di raffreddamento all in one integrati sino a una nuova scheda video GeForce RTX 5090. In sottofondo il tema dell'intelligenza artificiale con una workstation molto potente per installazioni non in datacenter
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


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...
Le novità MSI del 2026 per i videogiocatori Le novità MSI del 2026 per i videogiocato...
I nuovi schermi QD-OLED di quinta generazione di MSI, per i gamers I nuovi schermi QD-OLED di quinta generazione di...
Il nuovo Snapdragon 8 Elite Gen 6 sar&ag...
Nintendo Switch 2: risultati sotto le at...
Weekend con tante sorprese su Amazon: to...
HONOR non si ferma più: il 2025 &...
Speciale best seller: EUREKA J15 Evo Ult...
Roborock Q10 X5+ da 10.000 Pa a 199€ &eg...
E-mail reset password di Instagram: la c...
La NASA ha discusso le problematiche del...
Il razzo spaziale NASA SLS e la capsula ...
Stazione Spaziale Internazionale: Crew-1...
Samsung Galaxy S26 Ultra: la ricarica de...
Apple ha un nuovo partner per la sua App...
Trenitalia introduce il prezzo dinamico ...
OnePlus non si ferma più: c'&egra...
DAZN sconta il piano Full per 6 mesi, se...
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:11.


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