c语言--第一章练习题

第一章练习题
1.一个C程序的执行是从( A )。
A)本程序的main 函数开始,到main函数结束
B)本程序文件的第一个函数开始,到本程序文件的最后一个函数结束
C)本程序文件的第一个函数开始,到本程序main函数结束
D)本程序的main 函数开始,到本程序文件的最后一个函数结束

A) 本程序的main函数开始,到main函数结束
正确。C程序的执行总是从main函数开始,并在main函数中的return语句(如果有的话)执行完毕后结束。
B) 本程序文件的第一个函数开始,到本程序文件的最后一个函数结束
错误。C程序的执行不是从文件中的第一个函数开始,而是从main函数开始。
C) 本程序文件的第一个函数开始,到本程序main函数结束
错误。同样,C程序的执行不是从文件中的第一个函数开始,而是在main函数结束时整个程序才结束。
D) 本程序的main函数开始,到本程序文件的最后一个函数结束
错误。C程序的执行在main函数结束时即结束,不考虑文件中是否还有其他函数。

2.以下叙述不正确的是( D )。
A)一个C源程序必须包含一个main函数
B)一个C源程序可由一个或多个函数组成
C)C程序的基本组成单位是函数
D)在C程序中,注释说明只能位于一条语句的后面

A) 一个C源程序必须包含一个main函数
正确。C语言规定,每个独立的程序都必须包含一个main函数作为程序的入口点。
B) 一个C源程序可由一个或多个函数组成
正确。C语言程序由多个函数组成,包括用户自定义的函数和库函数。
C) C程序的基本组成单位是函数
正确。C语言程序是由函数组成的,其中main函数是特殊的,因为它是程序的入口点。
D) 在C程序中,注释说明只能位于一条语句的后面
错误。注释可以位于C程序的任何地方,只要它们不在字符串字面量中。它们可以单独占一行,也可以位于语句的末尾或之前。

3.以下叙述正确的是(C )。
A)在对一个C程序进行编译的过程中,可发现注释中的拼写错误
B)在C程序中,main 函数必须位于程序的最前面
C)C语言本身没有输入输出语句
D)C程序的每行中只能写一条语句

A) 在对一个C程序进行编译的过程中,可发现注释中的拼写错误
错误。编译器会忽略注释,因此不会检查注释中的拼写错误。
B) 在C程序中,main函数必须位于程序的最前面
错误。main函数可以在C程序的任何位置,只要它在程序被链接时是可访问的。
C) C语言本身没有输入输出语句
正确。C语言本身不提供输入输出语句,而是依赖于标准库中的函数(如printf和scanf)来进行输入输出操作。
D) C程序的每行中只能写一条语句
错误。C语言允许在单行中编写多条语句,只要它们用分号(;)分隔。

4.一个C语言程序是由( B)。
A)一个主程序和若干个子程序组成
B)函数组成
C)若干过程组成
D)若干子程序组成

A) 一个主程序和若干个子程序组成
错误。C语言程序不是由主程序和子程序组成,而是由函数组成。
B) 函数组成
正确。C语言程序由一系列函数组成,其中main函数是程序的入口点。
C) 若干过程组成
错误。C语言中没有“过程”的概念,它使用函数来组织代码。
D) 若干子程序组成
错误。虽然“子程序”有时被用作“函数”的同义词,但在C语言的上下文中,更标准的术语是“函数”。

5.计算机高级语言程序的运行方法有编译执行和解释执行两种,以下叙述中正确的是( A)。
A)C语言程序仅可以编译执行
B)C语言程序仅可以解释执行
C)C语言程序既可以编译执行又可以解释执行
D)以上说法都不对

A) C语言程序仅可以编译执行
正确。C语言是一种编译型语言,其源代码需要被编译成机器码才能执行。
B) C语言程序仅可以解释执行
错误。C语言不支持解释执行。
C) C语言程序既可以编译执行又可以解释执行
错误。C语言仅支持编译执行。
D) 以上说法都不对
错误。因为A选项是正确的。

6.以下叙述中错误的是(D )。
A)C语言的可执行程序是由一系列机器指令构成的
B)用C语言编写的源程序不能直接在计算机上运行
C)通过编译得到的二进制目标程序需要连接才可以运行
D)在没有安装C语言集成开发环境的机器上不能运行C源程序生成的.exe文件

A) C语言的可执行程序是由一系列机器指令构成的
正确。编译后的C程序确实是一系列机器指令的集合。
B) 用C语言编写的源程序不能直接在计算机上运行
正确。C语言源程序需要编译成机器码后才能执行。
C) 通过编译得到的二进制目标程序需要连接才可以运行
正确。在编译过程中,通常会产生多个目标文件(.obj或.o),这些文件需要链接成最终的可执行文件(如.exe)。
D) 在没有安装C语言集成开发环境的机器上不能运行C源程序生成的.exe文件
错误。只要机器上有兼容的操作系统和运行时环境,就可以运行C源程序生成的.exe文件,而不需要C语言集成开发环境。

7.以下叙述正确的是(B )。
A)C语言程序是由过程和函数组成的
B)C语言函数可以嵌套调用,例如: fun(fun(x))
C)C语言函数不可以单独编译
D)C语言中除了main函数,其他函数不可作为单独文件形式存在

A) C语言程序是由过程和函数组成的
错误。C语言程序是由函数组成的,没有“过程”的概念。
B) C语言函数可以嵌套调用,例如: fun(fun(x))
正确。C语言支持函数的嵌套调用。
C) C语言函数不可以单独编译
错误。C语言函数可以单独编译成目标文件,然后链接成最终的可执行文件。
D) C语言中除了main函数,其他函数不可作为单独文件形式存在
错误。C语言中的任何函数都可以作为单独文件(通常是.c文件)存在,并通过包含头文件(.h)来声明和调用。

8.【真题】一个C程序总是从(C )开始执行。
A、书写顺序的第一个函数
B、书写顺序的第一条执行语句
C、主函数
D、用户自定义函数

A、书写顺序的第一个函数
错误。C程序的执行总是从main函数开始,而不是书写顺序的第一个函数。
B、书写顺序的第一条执行语句
错误。同上,执行始于main函数。
C、主函数
正确。C程序的执行总是从main函数开始。
D、用户自定义函数
错误。用户自定义函数不是程序的入口点。

9.【真题】在一个C程序中( C)。
A、main函数出现在所有函数之前,C程序不一定都有main 函数
B、main 函数必须出现在所有函数之后,一个C程序必须有且仅有一个 main函数。
C、main 函数可以在任何地方出现,一个C程序必须有且仅有一个main函数。
D、main 函数出现在固定位置,一个C程序可以有多个 main函数。

A、main函数出现在所有函数之前,C程序不一定都有main 函数
错误。main函数可以在任何位置,但C程序必须有且仅有一个main函数。
B、main 函数必须出现在所有函数之后,一个C程序必须有且仅有一个 main函数。
错误。main函数的位置不是固定的,可以出现在任何位置。
C、main 函数可以在任何地方出现,一个C程序必须有且仅有一个main函数。
正确。这是C语言程序的基本规则。
D、main 函数出现在固定位置,一个C程序可以有多个 main函数。
错误。main函数的位置不固定,但C程序不能有多个main函数。

10.下列四组选项中,均不是C语言关键字的选项是(B)。
A)define IF type B)getc char printf
B)include case scanf D)while go pow

A) define IF type
错误。define是预处理指令,但IF和type(尽管type不是标准C的关键字,但在某些上下文中可能被视为保留字或特殊用途)可能被视为不准确的选项,因为IF通常大写为#if作为预处理指令,但这里考虑的是小写。然而,严格来说,它们都不是C语言的关键字。
B) getc char printf
正确。getc和printf是标准库函数,char是数据类型,它们都不是C语言的关键字。
C) include case scanf
错误。#include是预处理指令,case是关键字(用于switch语句),scanf是标准库函数。
D) while go pow
错误。while是关键字,go和pow(后者是标准库函数,但在此上下文中考虑)不是关键字,但由于while的存在,该选项不正确。

注意:对于A选项的解析有些模糊,因为IF通常不是小写使用的,且type虽非标准关键字,但在某些情况下可能被视为特殊。然而,根据题目要求“均不是C语言关键字的选项”,B选项是最明确的正确答案。

11.下列四组选项中,均是不合法的用户标识符的选项是( B )。
A)W P_0 do B) b-a goto int
B)float la0 _A D)-123 abc TEMP

在C语言中,用户标识符(也称为变量名、函数名等)的命名规则通常遵循以下原则:
标识符只能由字母(A-Z, a-z)、数字(0-9)和下划线(_)组成。
标识符的第一个字符不能是数字。
标识符不能与C语言的关键字相同。
现在,我们根据这些规则来分析每个选项:
A) W, P_0, do
W 和 P_0 都是合法的标识符。
do 是C语言的关键字,用于循环控制,因此不是合法的用户标识符。但由于选项中还有其他合法的标识符,所以A选项不符合题目要求的“均是不合法的用户标识符”。
B) b-a, goto, int
b-a 包含了减号(-),不是有效的标识符。
goto 是C语言的关键字,用于无条件跳转,因此不是合法的用户标识符。
int 也是C语言的关键字,用于声明整型变量,因此不是合法的用户标识符。
此选项中的所有标识符均不合法,符合题目要求。
注意:原答案中的B选项被重复列出,并且列出了不相关的 float la0 _A,这看起来是一个错误。这里我假设第二个B选项(实际上是C选项的误标)是 b-a goto int,并据此进行分析。
C) float, la0, _A
float 是C语言的关键字,用于声明浮点型变量,因此不是合法的用户标识符。
la0 和 _A 都是合法的标识符。
由于选项中包含合法的标识符,所以C选项不符合题目要求。
D) -123, abc, TEMP
-123 以数字开头,不是合法的标识符。
abc 和 TEMP 都是合法的标识符。
由于选项中包含合法的标识符,所以D选项不符合题目要求。
综上所述,均是不合法的用户标识符的选项是 B) b-a goto int。

12.【真题】下列不属于C语言关键字的有(C )。
A.static
B.enum
C.NULL
D.int

A. static:是C语言的关键字,用于声明静态变量或函数。
B. enum:是C语言的关键字,用于声明枚举类型。
C. NULL:虽然在C语言中广泛使用,但它实际上是一个宏定义,通常在stddef.h或stdlib.h中定义为(void*)0,因此它不是关键字。
D. int:是C语言的关键字,用于声明整型变量。
答案:C

13.【真题】可用作用户标识符的一组标识是( C )。
A、void define
B、a3-3 _123
C、For _abc
D、2a sizeof

A、void define:void和define都是C语言的关键字,不能作为用户标识符。
B、a3-3 _123:a3-3包含非法字符-,不能作为标识符。
C、For _abc:虽然For通常建议不用于标识符(因为它与for关键字仅大小写不同,可能引起混淆),但在C语言中它是合法的(不区分大小写的情况除外)。_abc是完全合法的标识符。
D、2a sizeof:2a以数字开头,不是合法的标识符。sizeof是C语言的关键字。
注意:尽管For可能不是最佳实践,但根据题目要求,它在这里是合法的。

14.【真题】C语言程序的3种基本结构是(D )。
A、循环结构、转移结构和顺序结构
B、循环结构、递归结构和转换结构
C、顺序结构、选择结构和递归结构
D、顺序结构、选择结构和循环结构

顺序结构:程序按照书写顺序执行。
选择结构:根据条件执行不同的代码块(如if-else语句)。
循环结构:重复执行一段代码直到满足特定条件(如for、while、do-while循环)

15.【真题】以下4个关于C语言的结论中,错误的是( D)。
A、用while语句实现的循环一定可用for 语句实现;
B、用for 语句实现的循环一定可用 while语句实现;
C、用do-while语句实现的循环一定可用 while 语句实现;
D、do-while 语句与while语句的区别是仅是关键字”while”出现的位置不同。

A 和 B:这两种循环结构在功能上是等价的,只是语法形式不同,因此可以用一种形式实现另一种形式的循环。
C:do-while循环至少执行一次循环体,然后检查条件。这可以通过在while循环之前手动执行一次循环体,然后检查条件来实现。
D:do-while语句与while语句的主要区别在于do-while至少执行一次循环体,而while在条件不满足时可能根本不执行循环体。因此,它们的区别不仅仅是while关键字出现的位置不同

16.【真题】关于程序模块化,以下叙述错误的是(C )。
A.程序模块化可以提高程序编制的效率
B.程序模块化可以提高代码复用率
C.程序模块化可以提高程序运行的效率
D.程序模块化可以提高调试程序的效率

A:通过模块化,程序员可以专注于较小的、定义良好的任务,从而提高编程效率。
B:模块可以被不同的程序重复使用,提高了代码复用率。
C:程序模块化主要影响的是编程、调试和维护的效率,而不直接影响程序运行时的效率(除非通过更好的组织减少了不必要的计算或数据访问)。
D:模块化的程序结构使得调试更加容易,因为可以单独测试和调试每个模块。

17.【真题】C语言在编译过程中,链接以后生成的是(B )
A.源文
B.可执行
C.目标
D.汇编

源文件:包含C语言代码的文本文件。
可执行文件:编译和链接完成后生成的文件,可以直接由计算机执行。
目标文件:源文件经过编译但尚未链接的文件,通常包含机器代码,但可能还包含一些外部引用。
汇编文件:源文件经过汇编器处理后的文件,包含汇编语言代码。

18.【真题】程序经过编译生成的是( B)
A、源文件
B、目标文件
C、可执行文件
D、编译文件

源文件:包含原始C语言代码的文件。
目标文件:源文件经过编译器编译后生成的文件,包含机器代码,但可能还需要链接才能生成可执行文件。
可执行文件:在编译和链接之后生成,可以直接在操作系统上运行。
编译文件:不是一个标准的术语,通常指的是编译过程中生成的文件,如目标文件或汇编文件。

19.【真题】不属于C语言基本数据类型的是( D)。
A.单精度型
B.字符型
C.双长整型
D.指针类型

单精度型:对应float类型。
字符型:对应char类型。
双长整型:在C99及以后的标准中,long long类型可以视为一种扩展的基本数据类型,尽管它不是传统意义上的“单精度”或“双精度”类型。但题目中的“双长整型”可能是一个对类似类型的非标准描述。
指针类型:不是基本数据类型,而是用于存储变量地址的复合类型。
注意:如果“双长整型”被视为一个非标准或误解的描述,那么更准确的选择应该是基于C语言标准中的基本数据类型定义。但在这里,我们按照题目可能的意图来选择答案。

20.设C语言中,一个int型数据在内存中占2个字节,则unsigned int 型数据的取值范围为( C )。
A)0~255 B)0~32767 C) 0~65535 D)0~2147483647

int型数据占2个字节(即16位),在大多数情况下,int是有符号的,其取值范围通常是-32768到32767(但这不是绝对的,因为int的大小可以因编译器和平台而异)。然而,题目明确指出了int占2个字节。
unsigned int是无符号的,因此它的取值范围是从0到2^16-1,即0到65535。

21.若x、i、j、k都是int型变量,则计算表达式x=(i=4,j=16,k=32)后,x的值为( C )。
A)4 B) 16 C) 32 D) 52

答案:C

解析:在C或类似的编程语言中,逗号运算符,用于顺序执行多个表达式,并返回最后一个表达式的值。因此,表达式x=(i=4,j=16,k=32)首先按顺序执行i=4、j=16、k=32,然后返回k=32的结果,即32。所以,x的值被赋为32。

22.【真题】已知int i,a; ,执行语句i=(a=23,a5),a+6;后变量i的值是( C )。
A、6 B、12 C、30 D、36

答案:C

解析:在C语言中,逗号运算符,同样用于顺序执行多个表达式,并返回最后一个表达式的值。i=(a=2*3,a*5)首先计算a=2*3(即a=6),然后计算a*5(即6*5=30),并将30赋值给i。a+6是一个独立的表达式,它的结果没有被使用或赋值给任何变量。因此,变量i的值是30。

23.【真题】以下变量定义合法的是( B,C )。
A. int 2n=1;
B.float define=1.234;
C. Char _hello= ‘\O’;
D.double x+1=2.5;

答案:B, C(但注意C选项的字符字面量写法有误,应为char _hello= '\0';)

解析:

A选项:变量名不能以数字开头,因此int 2n=1;是非法的。
B选项:float define=1.234;是合法的,因为它定义了一个float类型的变量define并初始化为1.234。
C选项:原题中的Char _hello= ‘\O’;是不合法的,因为Char应为大写char,且\O不是有效的转义字符(如果意图是表示空字符,应写为\0)。如果忽略这些错误,仅从变量定义的角度看,如果写为char _hello= '\0';,则是合法的。
D选项:变量名不能包含运算符(如+),因此double x+1=2.5;是非法的。

24.下列变量定义中合法的是( )。
A) short _a=015; 八进制
B) double b=e2.5;
C) long do=OxfdaL; 十六
D) float 2_and=1e-3;

答案:A

解析:

A选项:short _a=015;是合法的,因为015表示八进制数13(十进制),且变量名_a是合法的。
B选项:double b=e2.5;是非法的,因为e2.5不是有效的字面量,应使用科学记数法时,基数(e之前的部分)应为十进制数,如2.5e1。
C选项:long do=OxfdaL;中的OxfdaL是非法的,因为十六进制数应以0x或0X开头,但O不是0。正确的写法是0xfdaL。
D选项:float 2_and=1e-3;是非法的,因为变量名不能以数字开头。

25.下列四组选项中,均是合法转义字符的选项是( )。
A)‘\”’‘\’‘\n’
B)‘\’‘\017’‘\”’
C)‘\018’‘\f’‘\xab’
D)‘\O’‘\101’‘\xlf’

答案:A

解析:

A选项:‘\”’‘\\’‘\n’都是合法的转义字符,分别表示双引号、反斜杠和换行符。
B选项:‘\’‘\017’‘\”’中,第一个\后面没有跟任何字符,因此是非法的。
C选项:‘\018’是非法的,因为八进制数不能有8(只包含0-7)。
D选项:‘\\O’中的O不是有效的八进制数的一部分,且\xlf不是有效的转义字符(十六进制数应以0x或0X开头)。

26.下面不正确的字符常量是( )。
A)“c” B)‘l’ C)‘ ’ D)‘K’

答案:A) “c”

解析:在C语言中,字符常量是由单引号'包围的单个字符,如'l'、' '(空格字符)、'K'。而"c"是由双引号包围的,表示一个字符串常量,不是字符常量。

27.以下叙述不正确的是( )。
A)在C程序中,逗号运算符的优先级最低
B)在C程序中,MAX和 max是两个不同的变量
C)若a和b类型相同,在计算了赋值表达式a=b后,b中的值将放入a中,而b中的值不变
D)当从键盘输入数据时,对于整型变量只能输入整型数值,对于实型变量只能输入实型数值

答案:D) 当从键盘输入数据时,对于整型变量只能输入整型数值,对于实型变量只能输入实型数值

解析:在C程序中,从键盘输入数据时,对于整型变量可以输入整型数值,但也可以输入实数(此时输入的数据会被截断为整数部分)。对于实型变量,可以输入实数,也可以输入整数(整数会被自动转换为浮点数)。因此,D选项的叙述是不正确的。

28.以下叙述不正确的是( )。
A)在C程序中,逗号运算符的优先级最低
B)在C程序中,MAX和 max是两个不同的变量
C)若a和b类型相同,在计算了赋值表达式a=b后,b中的值将放入a中,而b中的值不变
D)当从键盘输入数据时,对于整型变量只能输入整型数值,对于实型变量只能输入实型数值

答案:D) 当从键盘输入数据时,对于整型变量只能输入整型数值,对于实型变量只能输入实型数值

解析:这个问题与27题相同,D选项的叙述依然是不正确的。

29.已知字母A的ASCII码为十进制数65,且 c2为字符型,则执行语句c2=‘A’+‘6’-‘3’后,c2中的值为( )。
A)D B)68 C)不确定的值 D)c

答案:A) D

解析:在C语言中,字符常量在内存中是以其ASCII码的形式存储的。已知'A'的ASCII码为65,'6'的ASCII码为54,'3'的ASCII码为51。执行c2='A'+'6'-'3'时,首先计算'A'+'6'得到119(65+54),然后减去'3'的ASCII码51,得到68。由于字符常量在内存中是以ASCII码形式存储的,因此68对应的字符是'D'。

30.sizeof(float)是( B )。
A)一个双精度型表达式
B)一个整型表达式
C)一种函数表达式
D)一个不合法的表达式

答案:B) 一个整型表达式

解析:sizeof是C语言中的一个操作符,用于获取某种数据类型或变量在内存中所占的字节数。sizeof(float)的结果是一个整数,表示float类型变量在内存中占用的字节数。因此,sizeof(float)是一个整型表达式。

31.设有说明: char w; int x; float y; double z;则表达式w*x+z-y值的数据类型为( )。
A) float B) char C) int D) double

答案:D) double

解析:在C语言中,当进行不同类型的数据运算时,会发生类型提升(Type Promotion)。在这个表达式w*x+z-y中,w是char类型,x是int类型,y是float类型,z是double类型。由于double类型的精度和范围都大于其他类型,因此整个表达式的结果会提升为double类型。具体来说,w和x会首先被提升为int类型(因为char在运算时会提升为int),然后与z(已经是double)进行运算,结果自然是double类型。y(float)在运算时也会被提升为double以匹配z。

32.设以下变量均为int类型,则值不等于7的表达式是( )
A)(x=y=6,x+y,x+1)
B)(x=y=6,x+y,y+1)
C)(x=6,x+1,y=6,x+y)
D)(y=6,y+1,x=y,x+1)

答案:B) (x=y=6,x+y,y+1)

解析:逗号运算符,用于顺序执行其左右两个表达式,并返回最右边表达式的值。在选项B中,(x=y=6,x+y,y+1)首先执行x=y=6(此时x和y都被赋值为6),然后计算x+y(结果为12,但这个值被逗号运算符忽略),最后返回y+1(即6+1=7),但题目要求找不等于7的表达式,这里显然是理解上的误区。实际上,如果我们按照逗号运算符的规则来理解,这个表达式的最终结果是7,但题目可能是想通过某种误导来测试对逗号运算符的理解。然而,从字面上看,没有一个选项直接给出不等于7的结果。但如果严格按照题目要求(找不等于7的表达式),那么B选项在逗号运算符的作用下,尽管最终计算了y+1,但题目可能意图是让人误以为它返回的是x+y的结果(即12),但实际上它返回的是y+1(即7)。不过,从逻辑严谨性出发,这里应该指出题目表述可能存在问题,因为按逗号运算符的规则,B选项确实等于7。但如果必须选一个,我们可以认为题目意图是考察对逗号运算符的误解,那么B选项因为通常的误解(以为返回x+y)而“看起来”不等于7,尽管实际上它等于7。

然而,更合理的解释可能是,题目想要考察的是逗号运算符的“副作用”和返回值之间的区别,以及赋值运算符的链式赋值。在这种情况下,我们可以注意到,虽然所有选项在赋值和计算后都“涉及”到7(因为都有x=6和y=6或类似的赋值),但只有B选项的最终返回值(即逗号运算符最右边的表达式的结果)是7,而其他选项可能由于计算顺序或赋值的不同,导致最终返回的不是直接通过y+1得到的7。但既然题目直接问的是“值不等于7的表达式”,且没有提供足够的信息来间接判断(比如通过程序的副作用来影响结果),那么我们可以认为这是一个有歧义的题目。不过,按照最直接的理解,B选项是唯一一个“看起来”可能不等于7但实际上等于7的选项(基于常见的误解)。但请注意,这种解释基于对题目意图的推测。

然而,如果我们忽略题目的潜在歧义,并假设它想要考察的是对逗号运算符和赋值运算符的理解,那么实际上没有一个选项的值“不等于7”,因为所有选项在逗号运算符的作用下,最终都返回了一个与7相等或计算结果为7的表达式的结果。但在这里,我们按照题目的字面意思和常见的误解来解释,选择B作为答案(尽管这个答案在严格意义上是不准确的)。

注意:这个题目可能存在歧义或错误,因为没有一个选项直接给出一个不等于7的表达式。上面的解释是基于对题目意图的推测和对逗号运算符、赋值运算符规则的理解。

33.putchar函数可以向终端输出一个( )。
A)整型变量表达式
B)实型变量值
C)字符串
D)字符或字符型变量值

33.
答案:D) 字符或字符型变量值

解析:putchar函数是C语言标准库中的一个函数,用于向标准输出(通常是终端或屏幕)输出一个字符。它接受一个int类型的参数,但通常这个参数是一个字符(用字符常量或字符变量表示)的ASCII码值。然而,在调用时,我们通常会传递一个字符常量或字符变量的值给putchar,它会将该值对应的ASCII码字符输出到屏幕上。

34.阅读以下程序,当输入数据的形式为:25,13,10(注:表示回车),则正确的输出结果为( )。
main()
{
int x,y,z;
scanf(“%d%d%d”,&x,&y,&z);
printf(“x+y+z=%din”,x+y+z);
}
A)x+y+7=48
B)x+y+z=35
C) x+z=35
D)不确定值

答案:B) x+y+z=35

解析:程序中的scanf函数用于从标准输入(通常是键盘)读取三个整数,并将它们分别赋值给变量x、y、z。根据题目描述,输入的数据是25,13,10<CR>(

35.根据下面的程序及数据的输入和输出形式,程序中输入语句的正确形式应该为( )。
main( )
{
char ch1,ch2,ch3;输入语句
printf(“%c %c %c”,ch1,ch2,ch3);
}
输出形式:A B C
输入形式:A B C
A) scanf(“%c%c%c”,&ch1,&ch2,&ch3);
B) scanf(“%c,%c,%c”,&ch1,&ch2,&ch3);
C) scanf(”%c %c %c”,&ch1,&ch2,&ch3);
D) scanf(“%c%c”,&ch1,&ch2,&ch3);

答案:A) scanf(“%c%c%c”,&ch1,&ch2,&ch3);

解析:根据程序的输出形式A B C和要求的输入形式A B C(注意输入之间没有用逗号、空格或其他分隔符分隔),我们需要一个scanf语句来连续读取三个字符并分别存储到ch1、ch2、ch3中。

A选项scanf(“%c%c%c”,&ch1,&ch2,&ch3);正确地使用了%c格式说明符来读取字符,并且没有在格式字符串中指定任何分隔符,这允许scanf从输入流中连续读取三个字符。
B选项scanf(“%c,%c,%c”,&ch1,&ch2,&ch3);在格式字符串中指定了逗号作为分隔符,但根据题目要求的输入形式,输入之间并没有逗号,因此这个选项不正确。
C选项scanf("%c %c %c”,&ch1,&ch2,&ch3);的格式字符串中包含了空格作为分隔符,这在某些情况下(如输入之间有额外空格时)可能有效,但题目明确指出了输入之间没有空格或其他分隔符,因此这个选项也不是最佳答案。然而,值得注意的是,在C语言中,scanf的%c格式说明符会读取任何字符,包括空格,但在这个特定情况下,由于输入之间没有空格,它仍然能够正确工作。然而,由于A选项更直接地符合题目要求,因此A是更优的选择。
D选项scanf(“%c%c”,&ch1,&ch2,&ch3);只指定了两个%c格式说明符,这意味着它只能读取并存储两个字符,而题目要求读取三个字符,因此这个选项不正确。

  • 18
    点赞
  • 19
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值