1.字符输出函数putchar

putchar函数是字符输出函数,其功能是在终端(显示器)输出单个字符。其一般调用形式为:

putchar(字符变量);

例:

123

putchar(‘A’); /*输出大写字母A */putchar(x); /*输出字符变量x的值*/putchar(‘n’); /*换行*/

2、字符输入函数getchar

getchar函数的功能是接收用户从键盘上输入的一个字符。其一般调用形式为:

getchar();

getchar会以返回值的形式返回接收到的字符.通常的用法如下:

1234

char c; /*定义字符变量c*/c=getchar(); /*将读取的字符赋值给字符变量c*/

3、格式化输出函数printf

printf函数叫做格式输出函数,其功能是按照用户指定的格式,把指定的数据输出到屏幕上.printf函数的格式为:

printf(“格式控制字符串”,输出表项);

其中格式控制字符串用来说明输出表项中各输出项的输出格式(好比我要吃苹果,告诉printf是做成罐头吃还是直接吃)。输出表项列出了要输出的项,各输出项之间用逗号分开。输出表项也可以没有,则表示输出的是格式字符串本身。

格式控制字符串有两种:格式字符串和非格式字符串。非格式字符串在输出的时候原样打印;格式字符串是以%打头的字符串,在”%”后面跟不同格式字符,用来说明输出数据的类型、形式、长度、小数位数等。格式字符串的形式为: % [输出最小宽度] [.精度] [长度] 类型

例如,%d格式符表示 用十进制整形格式输出。%f表示用实型格式输出,%5.2f 格式表示输出宽度为5(包括小数点),并包含2位小数。常用的输出格式及含义如下:

格式字符

d , i

以十进制形式输出有符号整数(正数不输出符号)

O

以八进制形式输出无符号整数(不输出前缀0)

x

以十六进制形式输出无符号整数(不输出前缀0x)

U

以十进制形式输出无符号整数

f

以小数形式输出单、双精度类型实数

e

以指数形式输出单、双精度实数

g

以%f或%e中较短输出宽度的一种格式输出单、双精度实数

C

c语言输入数字输出字母_c语言本身没有输入输出语句_输入三个数输出最大值c语言

输出单个字符

S

输出字符串

关于printf的更多用法,请您自行上机实验。

例如

1234567891011121314

#includeint main(){int a=12;float b=3.1415;char c=’A’;printf(“%dn”,a);printf(“o%on”,a);printf(“0x%xn”,a);printf(“%3.2fn”,b);printf(“%cn”,c);getchar();return 0;}

*修饰符在printf()中的用法:

假如您不想事先指定字段宽度,而是希望由程序来制定该值,那么您可以在字段宽度部分使用*代替数字来达到目的,但是您也必须使用一个参数来告诉函数宽度的值是多少。具体的说,如果转换说明符为%*d,那么参数列表中应该包括一个*的值和一个d的值,来控制宽度和变量的值。该技术也可以和浮点值一起使用来指定精度和字段宽度。

您可以参考下面的例子:

123456789101112131415

/*使用可变宽度输出字段*/#includeint main(void){unsigned width,precision;int number = 256;double weight = 25.5;printf(“Please input number’s width:n”);scanf(“%d”,&width);printf(“The number is: %*dn”,width,number);printf(“Then please input width and precision:n”);scanf(“%d %d”,&width,&precision);printf(“Weight = %*.*fn”,width,precision,weight);return 0;}

gcc运行 下运 行过程及结果如下:

123456

Please input number’s width:6The number is: 256Then please input width and precision:8 3Weight = 25.500

关于printf()的返回值:

printf函数的返回值是返回所打印的字符的数目。如有输出错误,那么printf()会返回一个负数(printf()的一些老版本会有不同的值)。

输入三个数输出最大值c语言_c语言输入数字输出字母_c语言本身没有输入输出语句

4、格式化输入函数scanf

scanf函数称为格式输入函数,即按照格式字符串的格式,从键盘上把数据输入到指定的变量之中。Scanf函数的调用的一般形式为:

scanf(“格式控制字符串”,输入项地址列表);

其中c语言本身没有输入输出语句,格式控制字符串的作用与printf函数相同,但不能显示非格式字符串,也就是不能显示提示字符串。地址表项中的地址给出各变量的地址,地址是由地址运算符”&”后跟变量名组成的。

Scanf 函数中格式字符串的构成与printf函数基本相同,但使用时有几点不同.

(1) 格式说明符中,可以指定数据的宽度,但不能指定数据的精度。

例:

123

float a;scanf(“f”c语言本身没有输入输出语句,&a); //正确scanf(“.2f”,&a); //错误

(2) 输入long类型数据时必须使用%ld,输入double数据必须使用%lf或%le。

(3) 附加格式说明符”*”使对应的输入数据不赋给相应的变量。

scanf()函数所用的转换说明符与printf()所用的几乎完全相同。主要区别在于printf()把%f、%e、%E、%g、%G同时用于float类型和double类型,而scanf()只是把他们用于float类型,而用于double类型时要求使用l(字母l)修饰符。

转换说明符

%c

把输入解释成一个字符

%d

把输入解释成一个有符号十进制整数

输入三个数输出最大值c语言_c语言本身没有输入输出语句_c语言输入数字输出字母

%e,%f,%g,%a

把输入解释成一个浮点数(%a是C99的标准)

%E,%F,%G,%A

把输入解释成一个浮点数(%A是C99的标准)

%i

把输入解释成一个有符号十进制整数

%o

把输入解释成一个有符号的八进制整数

%p

把输入解释成一个指针(一个地址)

%s

把输入解释成一个字符串:输入的内容以第一个非空白字符作为开始,并且包含直到下一个空白字符的全部字符

%u

把输入解释成一个无符号十进制整数

%x,%X

把输入解释称一个有符号十六进制整数

*修饰符在scanf中()的用法:

*在scanf()中提供截然不同的服务,当把它放在%和说明符字母之间时,它使函数跳过相应的输入项目。请参考程序事例:

例:

/*用*跳过scanf接收的数字*/

#include

int main(void)

{

int num;

printf(“Please enter three number:n”);

scanf(“%*d %*d %d”,&num);

printf(“The last number is %dn”,num);

return 0;

}

gcc下

123

Please enter three number:2014 2015 2016The last number is 2016

关于scanf()的返回值

scanf() 函数返回成功读入的项目的个数。如果它没有读取任何项目(比如它期望接收一个数字而您却输入的一个非数字字符时就会发生这种情况),scanf()返回0。

当它检测到“文件末尾”(end of file)时,它返回EOF(EOF在是文件stdio.h中的定义好的一个特殊值,一般,#define指令将EOF的值定义为-1)。当您学过循环之后,或在参加ACM这样的比赛及使用在线评测系统的时候会经常用到这种写法。

发表回复

您的电子邮箱地址不会被公开。 必填项已用*标注