Chinaunix首页 | 论坛 | 博客
  • 博客访问: 728513
  • 博文数量: 204
  • 博客积分: 6552
  • 博客等级: 准将
  • 技术积分: 2724
  • 用 户 组: 普通用户
  • 注册时间: 2007-09-29 18:41
文章分类

全部博文(204)

文章存档

2012年(6)

2011年(66)

2010年(99)

2009年(31)

2008年(2)

我的朋友

分类: C/C++

2010-08-03 13:27:35

使用的理由(范围):如果输入数据很庞大,需要一次又一次的重新输入和调试时可采用本函数。

freopen ()函数:

1.格式

FILE * freopen ( const char * filename, const char * mode, FILE * stream );

2.参数说明

filename: 要打开的文件名

mode: 文件打开的模式,和fopen中的模式(r/w)相同

stream: 文件指针,通常使用标准流文件(stdin/stdout/stderr)

返回值:成功,则返回一个path所指定文件的指针;失败,返回NULL。(一般可以不使用它的返回值) 
功能:实现重定向,把预定义的标准流文件定向到由path指定的文件中。标准流文件具体是指stdinstdoutstderr。其中stdin是标准输入流,默认为键盘;stdout是标准输出流,默认为屏幕;stderr是标准错误流,一般把屏幕设为默认。通过调用freopen,就可以修改标准流文件的默认值,实现重定向。

3.使用方法

因为文件指针使用的是标准流文件,因此我们可以不定义文件指针。

接下来我们使用freopen()函数以只读方式r(read)打开输入文件slyar.in

freopen("slyar.in", "r", stdin);

然后使用freopen()函数以写入方式w(write)打开输出文件slyar.out

freopen("slyar.out", "w", stdout);

接下来的事情就是使用freopen()函数的优点了,我们不再需要修改scanfprintf,而是维持代码的原样就可以了。因为freopen()函数重定向了标准流,使其指向前面指定的文件

最后只要使用fclose关闭输入文件和输出文件即可。

fclose(stdin);

fclose(stdout);

若要恢复句柄,可以重新打开标准控制台设备文件,只是这个设备文件的名字是与操作系统相关的。

DOS/Windows:

freopen("CON", "r", stdin);

Linux:

freopen("/dev/console", "r", stdin);

4.算法实

输入一些整数,求出它们的最小值、最大值和平均值(保留3位小数)。输入保证这些数都是不超过1000的整数。

样例输入:2 8 3 5 1 7 3 6

样例输出:1 8 4.375

参考程序1

#define TEST

#include

#define MM 1000

main()

{

#ifdef TEST

freopen("d:\\c2_4_in.txt","r",stdin);

freopen("d:\\c2_4_out.txt","w",stdout);

#endif

int i=0,sum=0,n,max=-MM,min=MM;

while(scanf("%d",&n)==1)

{

sum=sum+n;

if(max

max=n;

if(min>n)

min=n;

i++;

}

printf("%d %d %.3lf\n",min,max,(double)sum/i);

}

说明:(1)对于本题来说,我们使用了重定向简单地说,就是程序中用标准输入scanf()函数输入的数据从d:\c2_4_in.txt中读取,printf()函数输出的数据直接写入d:\c2_4_out.txt中去,屏幕上不在等待输入数据和不再显示输出结果。

2)如果把第一句去掉(#define TEST),

#ifdef TEST

freopen("d:\\c2_4_in.txt","r",stdin);

freopen("d:\\c2_4_out.txt","w",stdout);

#endif

就不起任何作用,这时还必须用标准输入输出。

 

参考程序2:

#include
#define MM 1000
main()
{
 FILE *fin,*fout;
 fin=fopen("d:\\c2_4_in.txt","rb");
 fout=fopen("d:\\c2_4_out.txt","wb");
 int i=0,n,sum=0,max=-MM,min=MM;
 while(fscanf(fin,"%d",&n)==1)
 {
  sum+=n;
  if(max   max=n;
  if(min>n)
   min=n;
  i++;
 }
 fprintf(fout,"%d %d %.3lf",min,max,(double)sum/i);
 fclose(fin);
 fclose(fout);
}

 

以上程序在VC6.0环境测试通过。
阅读(20486) | 评论(0) | 转发(2) |
给主人留下些什么吧!~~