第1章 C语言概述
习题(P13):
1.3 写出一个C程序的构成。
答:C程序由一个main函数和0个或多个自定义函数构成,每个函数的构成如下:
函数类型 函数名(函数参数列表)
{
说明部分
执行部分
}
1.4 C语言以函数为程序的基本单位,有什么好处?
答:一个函数实现一个相对独立的功能,便于实现程序的模块化。
1.5 请参照本章例题,编写一个C程序,输出以下信息:
*************************************************
Very good!
*************************************************
答:参照例1.1编程如下
# include <stdio.h>
void main()
{
printf("********************************************\n");
printf(" Very good!\n");
printf("********************************************\n");
}
1.6 编写一个C程序,输入a、b、c 3个值,输出其中最大者。
答:参照例1.3编程如下
法一:修改例1.3的主函数,自定义max函数不变。
# include <stdio.h>
void main()
{
int max(int x,int y); /*函数声明*/
int a,b,c,m; /*定义4个变量,m用于存放最大值*/
scanf("%d%d%d",&a,&b,&c);/*从键盘上输入3个整数*/
m=max(a,b); /*第一次调用max函数求出前两个数的最大值放在m中*/
m=max(m,c); /*再调max函数求出m和第三个数的最大数*/
printf("max is %d\n",m); /*输出结果*/
}
int max(int x,int y) /*定义求两个数的最大数的函数max */
{
int z;
if(x>y) z=x;
else z=y;
return(z);
}
法二:修改例1.3的主函数和max函数,将max函数改为求3个数的最大数。
# include <stdio.h>
void main()
{
int max(int x,int y,int z); /*函数声明*/
int a,b,c,m; /*定义4个变量,m用于存放最大值*/
scanf("%d%d%d",&a,&b,&c);/*从键盘上输入3个整数*/
m=max(a,b,c); /*直接调用max函数求出3个数的最大值放在m中*/
printf("max is %d\n",m); /*输出结果*/
}
int max(int x,int y,int z) /*定义求三个数的最大数的函数max */
{
int t;
if(x>y) /*该双分支语句出x和y中的最大值存到变量t中*/
t=x;
else
t=y;
if(z>t) /*如果第三个数z大于前两个数的最大数t,则t中存z的值,否则t值不变*/
t=z;
return(t);
}
第2章 程序的灵魂—算法
(略)
第3章 数据类型、运算符与表达式
习题(66):
3.2 C语言为什么要规定对所有用到的变量要“先定义,后使用”。这样做有什么好处?
见教材第39~40页
3.3请将下面各数用八进制数和十六进制数表示:
方法:正数可以采用“除基反序取余”的方法得到转换结果,但负数在内存中是按补码存放的。所以针对负数的转换方法是先将其绝对值转换为二进制,然后表示为原码(注意:符号位为1,并且在符号位和数值之间加0补足16位),再对原码求反加1得到其补码,最后按从右到左分组转换为八进制(三位二进制对应一位八进制)和十六进制(四位二进制位对应一位十六进制),符号位也看成是数值的一部分。
(1)10 (2)32 (3)75 (4)-617
(5)-111 (6)2483 (7)-28654 (8)21003
解:(1)10的机内存储形式为:0000000000001010 (16位,第1位为符号位)
所以有(10)10=(0000000000001010)2=(12)8
(10)10=(0000000000001010)2=(a)16
(2)32的机内存储形式为:0000000001000000
所以有(32)10=(0000000000100000)2=(40)8
(32)10=(00000000c语言程序设计教材答案00100000)2=(20)16
(3)75的机内存储形式为:0000000001001011
所以有(75)10=(0000000001001011)2=(113)8
(75)10=(0000000001001011)2=(4b)16
(4)-617的原码为:1000001001101001 (后10位为617的二进制,最高位为符号位)
求反加1后的补码(即机内存储形式)为:111111*********1
所以有(-617)10=(1111110110010111)2=(176627)8
(-617)10=(1111110110010111)2=(fd97)16
(5)-111的原码为:1000000001101111 (后7位为111的二进制,最高位为符号位)
求反加1后的补码(即机内存储形式)为:111111*********1
所以有(-111)10=(1111111110010001)2=(177621)8
(-111)10=(1111111110010001)2=(ff91)16
(6)2483的机内存储形式为:0000100110110011
所以有(2483)10=(0000100110110011)2=(4663)8
(2483)10=(0000100110110011)2=(9b3)16
(7)-28654的原码为:1110111********* (后15位为28654的二进制,最高位为符号位)
求反加1后的补码(即机内存储形式)为:1001000000010010
所以有(-28654)10=(1001000000010010)2=(110022)8
(-28654)10=(1001000000010010)2=(9012)16
(8)21003的机内存储形式为:010*********
所以有(21003)10=(0101001000001011)2=(51013)8
(21003)10=(0101001000001011)2=(520b)16
3.5 字符常量和字符串常量有什么区别?
解:字符常量是由一对单引号括起来的一个字符,存储时只需要1个字节的空间。字符串常量是由一对双引号括起来的0个或多个字符序列,在存储时系统自动在字符串末尾加一个结束符’\0’ 即比实际的字符个数多1个字节的存储空间。
3.6 写出以下程序的运行结果:
# include <stdio.h>
void main()
{
char c2='a',c2='b',c3='c',c4='\101',c5='\116';
printf("a%c b%c\tc%c\tabc\n",c1,c2,c3); /* \t为跳格,\n为回车换行*/
printf("\t \b%c %c\n",c4,c5); /* \b为退格*/
}
分析:该题中printf函数中的格式字符串中的普通字符原样输出,格式字符位置输出其后对应变量的字符形式,另要注意c4,c5变量是在 \ 后跟1~3位八进制形式的转义字符,实际表示的字符为将该八进制数转换成十进制,查ASCII码表得c4为’A’字符,c5为’N’字符。
运行结果为:aa0bb000cc000000abc
0000000A0N
说明: 0表示空格位
3.8 例3.6能否改成如下:
# include <stdio.h>
void main()
{
int c2,c2; /* 原为 char c1,c2; */
c1=97;
c2=98;
printf("%c%c",c1,c2);
printf("%d %d",c1,c2);
}
分析运行时会显示什么信息?为什么?
解:可以改,且运行结果为:ab
97 98
因为在可输出的字符范围内(0~255),用整型和用字符型作用相同。
3.9求下面算术表达式的值:
(1)x+a%3*(int)(x+y)%2/4
设x=2.5 , a=7 , y=4.7
(2)(float)(a+b)/2+(int)x%(int)y
设z=2 , b=3 , x=3.5 , y=2.5
解:(1)=2.5+7%3*(int)(2.5+4.7)%2/4
=2.5+1*(int)(7.2)%2/4
=2.5+1*7%2/4
=2.5+7%2/4
=2.5+1/4
=2.5+0
=2.5
(2)=(float)(2+3)/2+(int)3.5%(int)2.5
=(float)5/2+3%2
=2.5+1
=3.5
3.10写出下面程序的运行结果:
# include <stdio.h>
void main()
{
int i,j,m,n;
i=8;
j=10;
m=++i; /* 执行该语句后,m=9,i=9 */
n=j++; /* 执行该语句后,n=10,j=11 */
printf("%d,%d,%d,%d\n",i,j,m,n);
}
解:经分析程序执行后i=9,j=11,m=9,n=10,按最后一条输出语句得运行结果为:
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。
发表评论