首页 > 解决方案 > C、时钟函数只返回0.00000

问题描述

当我运行这段代码时,它每次打印 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);

}

我应该怎么做才能看到正常的输出?谢谢!

有些词是意大利语,所以:tempo 是时间,ordinaVett 是 sortArray,inizio 是 start,fine 是 end。

标签: c

解决方案


好吧,没关系,我意识到 CPU 太快了,双变量不能容纳这么简单的数字。这肯定是一个非常愚蠢的练习,放在教科书上。


推荐阅读