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程序,输入abc 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)  /*该双分支语句出xy中的最大值存到变量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=(00000000000010102=(12)8
(10)10=(00000000000010102=(a)16
  (2)32的机内存储形式为:0000000001000000   
所以有(32)10=(00000000001000002=(40)8
(32)10=(00000000c语言程序设计教材答案001000002=(20)16
(3)75的机内存储形式为:0000000001001011
所以有(75)10=(00000000010010112=(113)8
(75)10=(00000000010010112=(4b)16
(4)-617的原码为:1000001001101001        (后10位为617的二进制,最高位为符号位)
    求反加1后的补码(即机内存储形式)为:111111*********1
所以有(-617)10=(11111101100101112=(176627)8
(-617)10=(11111101100101112=(fd97)16
(5)-111的原码为:1000000001101111        (后7位为111的二进制,最高位为符号位)
    求反加1后的补码(即机内存储形式)为:111111*********1
所以有(-111)10=(11111111100100012=(177621)8
(-111)10=(11111111100100012=(ff91)16
(6)2483的机内存储形式为:0000100110110011
所以有(2483)10=(00001001101100112=(4663)8
(2483)10=(00001001101100112=(9b3)16
(7)-28654的原码为:1110111*********    (后15位为28654的二进制,最高位为符号位)
    求反加1后的补码(即机内存储形式)为:1001000000010010
所以有(-28654)10=(10010000000100102=(110022)8
(-28654)10=(10010000000100102=(9012)16
(8)21003的机内存储形式为:010*********
所以有(21003)10=(01010010000010112=(51013)8
(21003)10=(01010010000010112=(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求下面算术表达式的值:
1x+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=9j=11m=9n=10,按最后一条输出语句得运行结果为:

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。