DEV-C++中编写了一段C程序,其中设置了用文件进行输入输出。
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了DEV-C++中编写了一段C程序,其中设置了用文件进行输入输出。相关的知识,希望对你有一定的参考价值。
当运行后能够看到输出的文件:data,但是因为没有输入数据,所以结果不正确,我想问问,输入文件我需要再建立一个输入文件data.in记事本文件吗?但是建立后,无法和程序进行连接,是不是还需要再怎么操作?请各位大侠详细指点。
程序如下:
#define LOCAL
#include<stdio.h>
#define INF 1000000000
int main()
#ifdef LOCAL
freopen ("data.in","r",stdin);
freopen ("data.out","w",stdout);
#endif
int x,n=0,min=INF,max= -INF,s=0;
while(scanf("%d",&x)==1)
s+=x;
if(x<min) min=x;
if(x>max) max=x;
n++;
printf("%d %d %.3f\n",min,max,(double)s/n);
return 0;
标准输入输出:
1. scanf, printf
int scanf(const char *format, arg_list)
scanf主要从标准输入流中获取参数值,format为指定的参数格式及参数类型,如scanf("%s,%d",str,icount);
它要求在标准输入流中输入类似"son of bitch,1000"这样的字符串,同时程序会将"son of bitch"给str,1000给icount。
scanf函数的返回值为int值,即成功赋值的个数,在上例中如果函数调用成功,则会返回2,所以我们在写程序时,可以通过语句
if( scanf("%s,%d",str,icount) != 2)
...
来判断用户输入是否正确.
例子:
#include <stdio.h>
#include <stdlib.h>
int main()
printf("Input Data:\n");
char str[64];
int num;
scanf("%s,%d", str, &num);
printf("%s,%d", str, num);
return 0;
Input Data:
nihao,1
nihao,1,2009091631
此处将","当做了与前面的nhao以及1一起的字符串。注意scanf时,是以空格,制表符以及回车作为变量之间的分割的。
因此在使用scanf时尽量采用这几个作为分割标记。而不要像scanf("%s,%d", str, &num);,它无法正确输入数据。
int printf(const char *format, arg_list)
printf主要是将格式化字符串输出到标准输出流中,在stdio.h头文件中定义了标准的输入和输出,分别是stdin,stdout。
arg_list可以是变量名,也可以是表达式,但最终都会以值的形式填充进format中
格式化输入输出:
1. 格式控制
格式控制是用双引号括起来的字符串,也称"转换控制字符串",它包含以下两部分信息。
格式说明:由"%"和格式字符组成,如%d,%f,%c,它的作用是把输出数据转换为指定格式输出,格式的说明总是由"%"字符开始的.
普通字符:需要原样输出的字符,或者是一些有特殊含义的字符,如\n,\t。
\n 换行
\f 清屏并换页
\r 回车
\t Tab符
\xhh 表示一个ASCII码用16进表示,其中hh是1到2个16进制数
2. 输出列表
就是需要输出的一些数据,也可以是表达式,如果在函数中需要输出多个变量或表达式,则要用逗号隔开。
一些特殊字符的输出:
单引号,双引号,和反斜杠的输出在前面加转义字符”\”,如:"\’", "\"", "\\"。
% 的输出用两个连在一起的%%,即 printf(“%%”);
常用的格式说明如下:
格式字符
d 以十进制形式输出带符号整数(正数不输出符号)
o 以八进制形式输出无符号整数(不输出前缀0)
x 以十六进制形式输出无符号整数(不输出前缀0x)
u 以十进制形式输出无符号整数
f 以小数形式输出单精度实数
lf 以小数形式输出双精度实数
e 以指数形式输出单、双精度实数
g 以%f,%e中较短的输出宽度输出单、双精度实数
c 输出单个字符
s 输出字符串
特殊:
对64位整数的输入输出,在POJ上的C++环境下(即VC),64位整数是:
__int64 (注意int前面是两个下划线),输入输出格式为”%I64d”.
在G++环境下(即Dev C++) 64位整数是
long long 输入输出格式为”%lld”.
输出宽度
用十进制整数来表示输出的最少位数。注意若实际位数多于定义的宽度,则按实际位数输出,若实际位数少于定义的宽度则补以空格或0。
可以在"%"和字母之间插进数字表示最大宽度。
%9.2f 表示输出场宽为9的浮点数,其中小数位为2,整数位为6,小数点占一位,不够9位右对齐。
%8s 表示输出8个字符的字符串, 不够8个字符右对齐。
如果字符串的长度,或整型数位数超过说明的场宽,将按其实际长度输出。
但对浮点数, 若整数部分位数超过了说明的整数位宽度, 将按实际整数位输出;
若小数部分位数超过了说明的小数位宽度,则按说明的宽度以四舍五入输出。
另外,若想在输出值前加一些0, 就应在场宽项前加个0。
例如: d 表示在输出一个小于4位的数值时, 将在前面补0使其总宽度为4位。
如果用浮点数表示字符或整型量的输出格式,小数点后的数字代表最大宽度,小数点前的数字代表最小宽度。
例如: %6.9s 表示显示一个长度不小于6且不大于9的字符串。若大于9,则第9个字符以后的内容将被删除。
精度
精度格式符以"."开头,后跟十进制整数。意义是:如果输出数字,则表示小数的位数;如果输出的是字符,则表示输出字符的个数;
若实际位数大于所定义的精度数,则截去超过的部分。
标志格式字符
- 结果左对齐,右边填空格
+ 输出符号(正号或负号)空格输出值为正时冠以空格,为负时冠以负号
例如:
double c = 24212345.24232;
printf(“%020.4”); 表示输出精确到小数点后4位,输出占20位,若有空余的位补0。
2. getc,putc
int getc(FILE *fp)
getc主要是从文件中读出一个字符.常用的判断文件是否读取结束的语句为:(ch = getc(fp)) != EOF。EOF为文件结束标志,
定义在stdio.h中,就像EXIT_SUCCESS,EXIT_FAILURE定义在stdlib.h中一样,文件也可以被理解为一种流,所以当fp为stdin时,
getc(stdin)就等同于getchar()了.
int putc(int ch,FILE *fp)
putc主要是把字符ch写到文件fp中去。如果fp为stdout,则putc就等同于putchar()了。
#include <stdio.h>
#include <stdlib.h>
int main()
FILE * fp = fopen("tmp.txt", "w+");
putc('a', fp);
fflush(fp);
fclose(fp);
fp = fopen("tmp.txt", "r+");
int c = getc(fp);
printf("%c\n", c);
fclose(fp);
int ch = getc(stdin);
putc( ch, stdout);
putc( '\n', stdout);
putc('a', stdout);
return 0;
3. getchar,putchar
int getchar(void)
getchar()主要是从标准输入流读取一个字符。默认的标准输入流即stdio.h中定义的stdin。但是从输入流中读取字符时又
涉及到缓冲的问题,所以并不是在屏幕中敲上一个字符程序就会运行,一般是通过在屏幕上敲上回车键,然后将回车前的字符
串放在缓冲区中,getchar() 就是在缓冲区中一个一个的读字符。当然也可以在while循环中指定终止字符,如下面的语句:
while ((c = getchar()) != '#')
这是以'#'来结束的。
int putchar(int ch)
putchar(ch)主要是把字符ch写到标准流stdout中去.
#include <stdio.h>
#include <stdlib.h>
int main()
int n;
while((n = getchar()) != '#')
putchar((char)n);
return 0;
4. gets,puts
char * gets(char *str)
gets() 主要是从标准输入流读取字符串并回显,读到换行符时退出,并会将换行符省去。
返回值为获得的字符串的首地址,实现链接操作。
int puts(char *str)
puts() 主要是把字符串str写到标准流stdout中去,并会在输出到最后时添加一个换行符。
返回值为0表示正常,非零表示错误
#include <stdio.h>
#include <stdlib.h>
int main()
char str[256];
printf("%s\n", gets(str));
int ret = puts(str);
printf("len: %d\n", ret);
return 0;
追问
您好!我这方面是菜鸟,能不能就我的这个问题帮我解释一下。我是不是还需要再写两条头文件,还是要怎么操作?我是对文件的输入输出不理解。通过这个程序,已经实现了文件的输出,而且也有一个记事本文件,那输入的数据我也要写在一个记事本文件中吗?然后重命名?还是该怎么操作?
参考技术A -物联网校企联盟技术部如何在 Bloodshed Dev-C++ 中使用 GCC 命令进行链接
【中文标题】如何在 Bloodshed Dev-C++ 中使用 GCC 命令进行链接【英文标题】:How to link using GCC commands in Bloodshed Dev-C++ 【发布时间】:2016-06-01 10:19:27 【问题描述】:我试图弄清楚如何链接 Fortran 和 C++ 代码,其中一个教程编写了 2 个程序,一个用 C++ 编写的文件名为 testC.cpp
,另一个使用 Fortran 编写的文件名为 testF.f
但我需要输入以下编译指令:
gfortran -c testF.f
g++ -c testC.cpp
g++ -o test testF.o testC.o -lg2c
问题是,我在一个名为 Bloodshed Dev-C++ 的 IDE 中工作,所以我不知道该怎么做。我尝试进入编译器选项,并在一般部分中将这些说明附加到选项“调用编译器时添加以下命令”中。没用。
【问题讨论】:
什么是“不起作用!”?这不是问题陈述。实际发生了什么?有什么消息吗?你是怎么想到-lg2c
的?应该是-lgfortran
。
专业提示:不要使用 Bloodshed Dev-C++(你在哪个石器时代的洞穴中发现了这个遗物?)。它是旧的,这意味着它非常旧,它实际上已经不再相关,并且会引起很多头痛,从而破坏学习的乐趣。
@rubenvb 你建议在 Windows 上使用什么 IDE?一个很容易像我发布的那样链接到 gcc 的?
Qt 创建者,Eclipse,代码::块。您可以从here 获取 MinGW-w64(即 GCC for Windows)。
当然我的意思是g++ -o test testF.o testC.o -lgfortran
。我认为这很明显。再说一次“不起作用”没有任何意义。
【参考方案1】:
也许您需要使用自定义 Makefile。项目->项目选项。或者包含 *.mak 文件
【讨论】:
以上是关于DEV-C++中编写了一段C程序,其中设置了用文件进行输入输出。的主要内容,如果未能解决你的问题,请参考以下文章