1、问题描述:
C语言自定义函数的printf()功能无法实现,不能打印自定义函数的tick的值。目的是通过比较循环和递归的程序运行的时间,自己自定义了俩个函数,去打印1-N的数值,然后有定义了俩个函数去调用这俩个函数,为什么无法显示呢?
2、代码如下:
//运行环境 IDE:Microsoft Visual Studio 2010
//程序教程:https://www.icourse163.org/learn/ZJU-93001?tid=1207006212#/learn/content?type=detail&id=1212031623&cid=1215166133
#include<stdio.h>
#include<time.h>//计算时间的库
#include<windows.h>
#include<stdlib.h>
clock_t start , stop; //clock_t是clock()函数返回的变量类型
double duration;
//程序:循环打印
void PrintNLoop(int N)
{
int k;
for( k=1;k<=N;k++)
{
printf("%d\n",k);
}
return ;
}
//程序:递归打印
void PrintNRecursive(int N)
{
if (N)
{
PrintNRecursive(N-1);
printf("%d\n",N);
}
return ;
}
int Loop(int N)//调用自定义循环
{
printf("下面用循环实现:\n");
start=clock();
PrintNLoop(N);
stop=clock();
duration=(double)(stop-start)/CLK_TCK;
printf("LoopTicks=%f \n",duration);
printf("LoopDuration:%6.2f\n\n",duration);
return 0;
}
int Recursive(int N)//调用自定义递归程序
{
printf("下面用递归实现:\n");
start=clock();
PrintNRecursive(N);
stop=clock();
duration=(double)(stop-start)/CLK_TCK;
printf("RecursiveTicks=%f \n",duration);
printf("RecursiveDuration:%6.2f\n\n",duration);
return 0;
}
int main ()
{
int N;
scanf("%d",&N);
PrintNLoop(N);//调用循环打印的程序
PrintNRecursive(N);//调用递归打印的程序
system("pause");
return 0;
}```