C,时钟功能返回仅0.00000

时间:2019-01-31 15:58:59

标签: c

当我运行此代码时,它每次打印0.000000而不是看起来像的东西:

#include <stdio.h>
#include <time.h>
#define n 10

void ordinaVett(int v[], int elem){

    clock_t inizio, fine;
    double tempo;
    int i, j, x, posmin, tmp;
    printf("\n\nOrdinamento vettore di %d elementi per %d volte: \n", elem, n);
    printf("Sele-sort:\n");
    for(x = 0; x < n; x++){ 
        inizio = clock();
        //Ordinamento con Sele-sort         
        for(i = 0; i < elem - 1; i++){
            posmin = i;
            for(j = i + 1; j < elem; j++){
                if(v[j] < v[posmin])
                posmin = j;
            }
            if(posmin != i){
                tmp = v[i];
                v[i] = v[posmin];
                v[posmin] = tmp;
            }
        }
        fine = clock();
        //Visualizzazione vettore
        for(i = 0; i < elem; i++){
            printf("%d |", v[i]);
        }
        tempo = (double)(fine - inizio)/CLOCKS_PER_SEC;
        printf("   Tempo: %f\n", tempo);
    }
}

int main(){

    srand(time(NULL));

    int elementi = 20, i;
    int v[elementi];

    printf("Creazione vettore 20 elementi: \n");
    for(i = 0; i < elementi; i++)
    {
        v[i] = rand() % 1001;
        printf("%d |", v[i]);
    }
    ordinaVett(v, elementi);

}

我应该为能够看到正常输出呢? 谢谢!

一些词在意大利这样:速度是时间,ordinaVett是sortArray,inizio是启动和细是端

1 个答案:

答案 0 :(得分:0)

好吧,没关系,我意识到CPU太快了,并且double变量不能容纳这么简单的数字。可以肯定,这很愚蠢。