下面C语言代码使用了生成随机数的函数、延时函数。请大家仔细观察其显示效果。
从以下代码,我们可以得出一个重要的结论:当上述两类函数被放入循环时,应作出一定修改。同时还应关注其参数的定义位置(子函数外?子函数内?全局变量?局部变量?)。
另外大家要注意:scanf在输入double型时,应该使用%lf,而在printf时却只需使用%f.
#include<stdio.h>
#include<time.h>
#include<stdlib.h>
double t_delay;
time_t start,end; //start,end修改后的位置
int createOrNot()
{
int flag;
//srand(time(NULL) );//srand()原先的位置
flag = (int)( (2*rand()/RAND_MAX) +1 );
return flag;//return 1 or 2
//1 create,2 not create.
}
void delay()
{
time_t start,end;//end原先的位置
double dif;
time (&start);
while( (dif= difftime (end,start) )<5000.0 )//注意这里
{
time (&end);
};
}
void delay(time_t end )//end修改后的位置
{
time_t start;//,end;
double dif;
time (&start);
while( (dif= difftime (end,start) )<2.0 )//注意这里
{
time (&end);
};
}
void delay(time_t end,double time_delay)//change...
{
time_t start;//,end;//change...
double dif;
time (&start);
time (&end);
while( (dif= difftime (end,start) ) < time_delay )
{
time (&end);
};
}
void delay(time_t start,time_t end)//change...
{
//time_t start;//,end;//change...
double dif;
time (&start);
time (&end);
while( (dif= difftime (end,start) ) < t_delay )
{
time (&end);
};
}
int main()
{
int i,flag = 1,times =10;
//time_t start,end; //start,end修改后的位置
srand(time(NULL) );//修正后,srand()所应在的位置。
for(i=0;i<times;i++)
{
flag= createOrNot();
printf("%d\n",flag);
delay();
//delay(end);
}
printf("\n\n");
for(i=0;i<times;i++)
{
flag= createOrNot();
printf("%d\n",flag);
//delay();
delay(end);
}
printf("t_delay:\n");
scanf("%lf",&t_delay);/////////////////////////////////////
//printf("t_delay:%f\n",t_delay);
for(i=0;i<times;i++)
{
flag= createOrNot();
printf("%d\n",flag);
//delay();
delay(end,t_delay);
}
printf("t_delay:\n");
scanf("%lf",&t_delay);
for(i=0;i<times;i++)
{
flag= createOrNot();
printf("%d\n",flag);
//delay();
delay(start,end);
}
}
版权与免责声明
1、本站所发布的文章仅供技术交流参考,本站不主张将其做为决策的依据,浏览者可自愿选择采信与否,本站不对因采信这些信息所产生的任何问题负责。
2、本站部分文章来源于网络,其版权为原权利人所有。由于来源之故,有的文章未能获得作者姓名,署“未知”或“佚名”。对于这些文章,有知悉作者姓名的请告知本站,以便及时署名。如果作者要求删除,我们将予以删除。除此之外本站不再承担其它责任。
3、本站部分文章来源于本站原创,本站拥有所有权利。
4、如对本站发布的信息有异议,请联系我们,经本站确认后,将在三个工作日内做出修改或删除处理。
请参阅权责声明!