第一题
1. 已有定义int x; float y; 且执行scanf("%3d%f", &x, &y);语句时,假设输入数据为12345□678↙,则x、y的值分别为(C ), 解释原因。
A. 12345 678.000000
B. 123 678.000000
C. 123 45.678000
D. 123 45.000000
原因:scanf(%3d)取前三位:123,所以排除A;scanf(%f)取45 678,且为float是六位小数,所以取45.678000
第二题
2. 阅读以下程序,当输入数据的形式为:12a345b789↙,已知正确答案为(A),请用文字解释原因。
void main ( ) { char c1, c2; int a1, a2; c1 = getchar ( ); scanf ("%2d", &a1); c2 = getchar ( ); scanf ("%3d", &a2); printf ("%d, %d, %c, %c\\n", a1, a2, c1, c2); } |
A. 2, 345, 1, a
B. 12, 345, a, b
C. 2a, 45b, 1, 3
D. 2, 789, 1, a
原因:getchar()函数获取输入字符并赋值给c1,c2;后使用scanf()函数读a1,a2,%2d为读两位整数,%3d为读三位整数
第三题
3. 填空: 以下程序的输出结果为:__17___21___11_。
void main( ) { int k=17; printf("%d, %o, %x\\n", k, k, k); } |
第四题
4. 填空: 以下程序的输出结果为_3.140000____3.142____。
#include <stdio.h> void main( ) { printf("\*%f, %4.3f\*\\n", 3.14, 3.1415); } |
第五题
5. 在Dev Cpp平台上新建一个项目,仿照PPT【4.2.1键盘输入和屏幕输出(下)】,完成功能:在命令窗口输入任意大写英文字母,输出值为对应的小写英文字母。
#include<stdio.h>
int main()
{
char input;
printf("请输入一个大写字母:");
scanf("%c",&input);
printf("对应的小写字母:%c",input+32);
return 0;
}
第六题
6. 在Dev Cpp平台上新建一个项目,输入下方截图的程序代码(同样也是上课的例子)。假设输入a=12, b=’a’, c=3.5,观察其输出。在这个过程中,程序出现了什么问题,应该如何补救?请对补救方法重新生成一段新的程序,并观察其输出。(要求在CSDN/博客园上粘贴下方代码,以及输入输出截图;改进后的代码,以及改进后的输入输出截图)
改进前:
#include<stdio.h>
main()
{
int a;
char b;
float c;
printf("Please input an integer:");
scanf("%d", &a);
printf("integer:%d\n",a);
printf("Please input a character:");
scanf("%c",&b);
printf("character:%c\n",b);
printf("Please input a float number:");
scanf("%f",&c);
printf("float:%f\n",c);
}
改进后:
#include<stdio.h>
main()
{
int a;
char b;
float c;
printf("Please input an integer:");
scanf("%d", &a);
printf("integer:%d\n",a);
printf("Please input a character:");
scanf(" %c",&b);
printf("character:%c\n",b);
printf("Please input a float number:");
scanf("%f",&c);
printf("float:%f\n",c);
return 0;
}