В приведенном ниже коде должно быть указано время выполнения в секундах цикла for. Если посмотреть на другие ресурсы, это должно сделать трюк, имеющий начальный clock()
, отложенный от clock()
после того, как цикл for запущен. Любые идеи, почему код не работает так, как написано?Поиск времени выполнения сегмента кода в C
#include <stdio.h>
#include <time.h>
//prototypes
int rfact(int n);
int temp = 0;
main()
{
int n = 0;
int i = 0;
double result = 0.0;
clock_t t;
printf("Enter a value for n: ");
scanf("%i", &n);
printf("n=%i\n", n);
//get current time
t = clock();
//process factorial 2 million times
for(i=0; i<2000000; i++)
{
rfact(n);
}
printf("n=%i\n", n);
//get total time spent in the loop
result = (double)((clock() - t)/CLOCKS_PER_SEC);
//print result
printf("runtime=%d\n", result);
}
//factorial calculation
int rfact(int n)
{
if (n<=0)
{
return 1;
}
return n * rfact(n-1);
}
Вы забыли задать вопрос. –
хорошо, что неловко. – zakparks31191