问题代码如下:
#include<stdio.h>
int main()
{ char c1,c2;
c1=97;
c2=98;
printf(“c1=%c,c2=%c\n”,c1,c2);
printf(“c1=%d,c2=%d\n”,c1,c2);
return 0;
}
- 运行时会输出什么信息?为什么?
- 如果将程序第4,5行改为
c1=197;
c2=198;
运行时会输出什么信息?为什么?
(3)如果将程序第3行改为
int c1,c2;
运行时会输出什么信息?为什么?
解答:
(1)运行时会输出:
c1=a, c2=b
c1=97, c2=98
因为 97
和 98
是字符 a
和 b
的ASCII码值。
(2)运行时会输出:
c1=�, c2=�
c1=197, c2=198
因为 197
和 198
超出了标准ASCII码的范围。
(3) 运行时会输出:
c1=a, c2=b
c1=97, c2=98
虽然类型不同,但由于 printf
的格式控制符 %c
和 %d
规定了输出字符和整数。
问题分析和解释说明:
任务:分析程序的输出和代码变更的影响。
原理:
- 原程序将字符变量
c1
和c2
初始化为ASCII值 97 和 98。 - 使用
%c
和%d
格式输出字符和对应的ASCII值。
步骤:
c1=97
和c2=98
分别是字符a
和b
,输出字符和ASCII值。- 修改
c1
和c2
为 197 和 198,超出ASCII范围,输出不可见字符。 - 修改
char
为int
,输出不变,因为printf
格式化决定输出内容。