《C语言程序设计》习题答案
- 格式:doc
- 大小:75.50 KB
- 文档页数:8
第1章程序设计和C语言11.1什么是计算机程序11.2什么是计算机语言11.3C语言的发展及其特点31.4最简单的C语言程序51.4.1最简单的C语言程序举例61.4.2C语言程序的结构101.5运行C程序的步骤与方法121.6程序设计的任务141-5 #include <stdio.h>int main ( ){ printf ("**************************\n\n"); printf(" Very Good!\n\n");printf ("**************************\n"); return 0;}1-6#include <stdio.h>int main(){int a,b,c,max;printf("please input a,b,c:\n");scanf("%d,%d,%d",&a,&b,&c);max=a;if (max<b)max=b;if (max<c)max=c;printf("The largest number is %d\n",max);return 0;}第2章算法——程序的灵魂162.1什么是算法162.2简单的算法举例172.3算法的特性212.4怎样表示一个算法222.4.1用自然语言表示算法222.4.2用流程图表示算法222.4.3三种基本结构和改进的流程图262.4.4用N S流程图表示算法282.4.5用伪代码表示算法312.4.6用计算机语言表示算法322.5结构化程序设计方法34习题36第章最简单的C程序设计——顺序程序设计37 3.1顺序程序设计举例373.2数据的表现形式及其运算393.2.1常量和变量393.2.2数据类型423.2.3整型数据443.2.4字符型数据473.2.5浮点型数据493.2.6怎样确定常量的类型513.2.7运算符和表达式523.3C语句573.3.1C语句的作用和分类573.3.2最基本的语句——赋值语句593.4数据的输入输出653.4.1输入输出举例653.4.2有关数据输入输出的概念673.4.3用printf函数输出数据683.4.4用scanf函数输入数据753.4.5字符数据的输入输出78习题823-1 #include <stdio.h>#include <math.h>int main(){float p,r,n;r=0.1;n=10;p=pow(1+r,n);printf("p=%f\n",p);return 0;}3-2-1#include <stdio.h>#include <math.h>int main(){float r5,r3,r2,r1,r0,p,p1,p2,p3,p4,p5;p=1000;r5=0.0585;r3=0.054;r2=0.0468;r1=0.0414;r0=0.0072;p1=p*((1+r5)*5); // 一次存5年期p2=p*(1+2*r2)*(1+3*r3); // 先存2年期,到期后将本息再存3年期p3=p*(1+3*r3)*(1+2*r2); // 先存3年期,到期后将本息再存2年期p4=p*pow(1+r1,5); // 存1年期,到期后将本息存再存1年期,连续存5次 p5=p*pow(1+r0/4,4*5); // 存活期存款。
c语言《程序设计基础》课后习题参考答案与解析《程序设计基础》习题参考答案与部分解析第1章 C 语言概述一、填空a) C源程序的基本单位是函数。
b) 一个C程序中至少应包括一个 main函数。
c) 在C语言中,输出操作是有库函数 printf( )函数完成。
二、单选题1、A2、C3、B解析:第1题答案:A 。
因为一个C程序总是从main函数开始执行的,而不论main函数在程序中的位置。
且到main函数结束。
第2题答案:C 。
因为 main函数没有限制必须位于程序的最前面。
C程序书写自由,一行内可写几个语句。
在对一个C 程序进行编译的过程中,无法检查注释当中的拼写错误。
不过C语言本身并没有输入输出语句,输入输出是由函数完成的。
第3题答案:B。
因为一个C语言程序是由若干个函数组成的。
但至少包含一个main 函数,且main函数的位置不限。
三、编程题1、编写一个输出“Welcome to C!”信息的小程序。
解:程序如下#include “stdio.h”main( ){1printf(“Welcome to C!”) ;}2、已知三角形的三边长分别为3,4,5,试用海轮公式编程求其面积。
海伦公式为:S?= ,其中s= (a+b+s)/2 ;解:程序如下#include “math.h”#include “stdio.h”main( ){int a , b , c ; /* a ,b,c 3个整型变量表示三角形的3条边。
*/float s ,s1 ; /* s1作为面积变量,s 作为中间变量是都应该是实形*/a=3 ; b= 4; c=5 ;s= (a+b+c)/2.0 ;s1= sqrt(s*(s-a)*(s-b)*(s-c)); /* sqrt函数完成开平方根功能。
*/printf(“area=%f\n”,s1);}2第2章程序设计基础知识一、单选题1、C2、A3、C4、A5、C6、C7、D8、C9、D 10、A 11、D 12、A 13、C 14、C 15、B A 16、B 17 D解析:1. 答案:C。
c语言程序设计习题答案C语言程序设计习题答案C语言是一门广泛应用于计算机科学领域的编程语言,掌握C语言的程序设计技巧对于计算机专业的学生来说至关重要。
在学习C语言的过程中,习题是一种非常有效的学习方式,通过练习不同类型的习题,可以提高编程能力和解决问题的能力。
本文将为大家提供一些C语言程序设计习题的答案,希望能够帮助大家更好地理解和掌握C语言。
习题一:编写一个C程序,计算并输出两个整数的和。
```c#include <stdio.h>int main() {int num1, num2, sum;printf("请输入两个整数:");scanf("%d %d", &num1, &num2);sum = num1 + num2;printf("两个整数的和为:%d\n", sum);return 0;}```习题二:编写一个C程序,判断一个整数是否为偶数。
```c#include <stdio.h>int main() {int num;printf("请输入一个整数:");scanf("%d", &num);if (num % 2 == 0) {printf("该整数是偶数。
\n");} else {printf("该整数是奇数。
\n");}return 0;}```习题三:编写一个C程序,找出一个整数数组中的最大值。
```c#include <stdio.h>int main() {int arr[] = {5, 2, 8, 10, 3};int size = sizeof(arr) / sizeof(arr[0]);int max = arr[0];for (int i = 1; i < size; i++) {if (arr[i] > max) {max = arr[i];}}printf("数组中的最大值为:%d\n", max);return 0;}```习题四:编写一个C程序,将一个字符串反转输出。
第一章C语言概述练习题一、选择题1. C语言是一种()。
A)机器语言B)汇编语言C)高级语言D)低级语言2. 下列各项中,不是C语言的特点是()。
A)语言简洁、紧凑,使用方便C)能实现汇编语言的大部分功能B)数据类型丰富,可移植性好D)有较强的网络操作功能3. 下列叙述正确的是()。
A)C语言源程序可以直接在DOS环境中运行B)编译C语言源程序得到的目标程序可以直接在DOS环境中运行C)C语言源程序经过编译、连接得到的可执行程序可以直接在DOS环境中运行D)Turbo C系统不提供编译和连接C程序的功能4. 下列叙述错误的是()。
A) C程序中的每条语句都用一个分号作为结束符B) C程序中的每条命令都用一个分号作为结束符C) C程序中的变量必须先定义,后使用D)C语言以小写字母作为基本书写形式,并且C语言要区分字母的大小写5. 一个C程序的执行是从()。
A)本程序的main函数开始,到main函数结束B)本程序文件的第一个函数开始,到本程序文件的最后一个函数结束C)本程序文件的第一个函数开始,到本程序main函数结束D)本程序的main函数开始,到本程序文件的最后一个函数结束6. 以下叙述不正确的是()。
A)一个C源程序必须包含一个main函数B)一个C源程序可由一个或多个函数组成C) C程序的基本组成单位是函数D)在C程序中,注释说明只能位于一条语句的后面7. C语言规定:在一个源程序中,main函数的位置()。
A)必须在程序的开头B)必须在系统调用的库函数的后面C)可以在程序的任意位置D)必须在程序的最后8. 一个C语言程序是由()。
A)一个主程序和若干个子程序组成B)函数组成C)若干过程组成D)若干子程序组成9. 以下有4组用户标识符,其中合法的一组是()。
A) For B) 4d C) f2_G3 D) WORD-sub DO IF voidCase Size abc define10. 一个算法应该具有“确定性”等5个特性,下面对另外4个特性的描述中错误的是A)有零个或多个输入B)有零个或多个输出C)有穷性D)可行性二、填空题1. 汇编语言属于面向(面向机器的)语言,局级语言属于(面向问题的)语言。
《程序设计语言C》课程习题集西南科技大学成人、网络教育学院版权所有习题【说明】:本课程《程序设计语言C》(编号为03004)共有单选题,编程题, 填空题等多种试题类型,其中,本习题集中有[ 填空题]等试题类型未进入。
一、单选题1.在C语言中,合法的长整型常数是AA) OL B) 4962710 C) 324562& D) 216D2.以下有4组用户标识符,其中合法的一组是CA) For B) 4d C) f2_G3 D) WORD3.以下选项中合法的字符常量是BA)"B" B) '\010' C) 68 D) D4.以下程序的输出结果是Dmain(){ int a=3;printf("%d\n",a+(a-=a*a) );}A) -6 B)12 C) 0 D) -125.设a、b、C、d、m、n均为int型变量,且a=5、b=6、c=7、d=8、m=2、n=2,则逻辑表达式(m=a>b)&&(n=c>d)运算后,n的值位为CA) 0 B) 1 C)2 D) 36.t为int类型,进人下面的循环之前,t的值为0while( t=l ) B{ ……}则以下叙述中正确的是A) 循环控制表达式的值为0 B) 循环控制表达式的值为1C) 循环控制表达式不合法D) 以上说法都不对7.在调用函数时,如果实参是简单变量,它与对应形参之间的数据传递方式是BA) 地址传递B) 单向值传递C) 由实参传给形参,再由形参传回实参D) 传递方式由用户指定8.以下程序的输出结果是Cmain(){ int i, a[10];for(i=9;i>=0;i- -) a[i]=10-i;printf("%d%d%d",a[2],a[5],a[8]);}A) 258 B) 741 C) 852 D) 3699.以下选项中,不能正确赋值的是AA) char s1[10];s1="Ctest"; B) char s2[]={'C', 't', 'e', 's', 't'};C) char s3[20]="Ctest"; D) char *s4="Ctest\n";10.以下程序的输出结果是Dunion myun{ struct{ int x, y, z; } u;int k;} a;main(){ a.u.x=4; a.u.y=5; a.u.z=6;a.k=0;printf("%d\n",a.u.x);}A)4 B) 5 C) 6 D) 011.以下叙述正确的是CA) C语言比其他语言高级B) C语言可以不用编译就能被计算机识别执行C) C语言以接近英语国家的自然语言和数学语言作为语言的表达形式D) C语言出现的最晚、具有其他语言的一切优点12. C语言中用于结构化程序设计的三种基本结构是AA) 顺序结构、选择结构、循环结构B) if、switch、breakC) for、while、do-while D) if、for、continue13.下列关于C语言用户标识符的叙述中正确的是BA) 用户标识符中可以出现下划线和中划线(减号)B) 用户标识符中不可以出现中划线,但可以出现下划线C) 用户标识符中可以出现下划线,但不可以放在用户标识符的开头D) 用户标识符中可以出现下划线和数字,它们都可以放在用户标识符的开头14.有以下程序段int m=0,n=0; char c=’a’;scanf("%d%c%d",&m,&c,&n);printf("%d,%c,%d\n",m,c,n);若从键盘上输入:10A10<回车>,则输出结果是:AA) 10,A,10 B) 10,a,10 C) 10,a,0 D) 10,A,015.有以下程序main()A{ int i;for(i=0;i<3;i++)switch(i){ case 1: printf("%d",i);case 2: printf("%d",i);default: printf("%d",i);}}执行后输出的结果是A) 011122 B) 012 C) 012020 D) 12016.有以下程序Bmain(){ int i=10,j=1;printf("%d,%d\n",i--,++j);}执行后输出的结果是A) 9,2 B) 10,2 C) 9,1 D) 10,117.有以下程序Dvoid f(int x,int y){ int t;if(x<y){ t=x; x=y; y=t; }}main(){ int a=4,b=3,c=5;f(a,b); f(a,c); f(b,c);printf("%d,%d,%d\n",a,b,c);}执行后输出的结果是A) 3,4,5 B) 5,3,4 C) 5,4,3 D) 4,3,518.有以下程序Cmain(){ char *s[]={"one","two","three"},*p;p=s[1];printf("%c,%s\n",*(p+1),s[0]);}执行后输出结果是A) n,two B) t,one C) w,one D) o,two19.有以下程序Cmain(){ int m[][3]={1,4,7,2,5,8,3,6,9};int i,k=2;for(i=0;i<3;i++){ printf("%d ",m[k][i]); }}执行后输出结果是A) 4 5 6 B) 2 5 8 C) 3 6 9 D) 7 8 920.设有如下说明typedef struct{ int n; char c; double x;}STD;则以下选项中,能正确定义结构体数组并赋初值的语句是AA) STD tt[2]={{1,’A’,62},{2,’B’,75}};B) STD tt[2]={1,"A",62,2,"",75};C) struct tt[2]={{1,’A’},{2,’B’}};D) struct tt[2]={{1,"A",62.5},{2,"B",75.0}};21.以下选项中属于C语言的数据类型是DA)复数型B)布尔型C)集合型D)整型22.一个C程序的执行是从AA)main()函数开始,直到main()函数结束B)第一个函数开始,直到最后一个函数结束C)第一个语句开始,直到最后一个语句结束D)main()函数开始,直到最后一个函数结束23.设有语句int a=3;则执行语句a+=a-=a*a;后,变量a的值是CA)3 B)0C)-12 D)924.若有 char c[5]={'c','d','\0','e','\0'};则执行语句printf("%s",c);结果是C A)cd\0e B)'c''d' C)cd D)cd e25.已知:int a[2][3]={1,2,3,4,5,6}, (*p)[3]=a;下列表达式不是4的是BA)*(*p+3) B)*p+3 C)*(*(p+0)+3) D)a[0][3]26.以下有宏替换不正确的叙述DA)宏替换不占用运行时间 B)宏名无类型C)宏替换只是字符串替换D)宏名必须用大写字母表示27.执行char str[10]=”Ch\nina”; strlen(str)的值是BA)5 B)6 C)7 D)928.下面程序的输出结果是D#define POWER(x) (x*x)main(){int i=4; printf("%d",POWER(i-2)); }A)-9 B)-7 C)5 D)-629.在定义int a[3][4];后,第10个元素是DA)a[2][4] B)a[3][2] C)a[3][3] D)a[3][1]30.下面程序的输出结果是Dtypedef struct{long x[2];short y[4];char z[8];}MYTYPE;MYTYPE a;main(){ printf("%d\n",sizeof(a));}A)2 B)8 C)14 D)2431.以下能正确进行字符串赋值的是CA)char s[5]={‘a’,’e’,’I’,’o’,’u’} B)char s[5];s=”good”C)char s[5]=”abcd” D)char s[5];s[]=”good”32.若有float x;则sizeof(x)和sizeof(float)两种描述AA)都正确B)都不正确C)前者正确,后者不正确D)后者正确,前者不正确33.若有代数式3ae/(bc),则不正确的C语言表达式是AA)3*a*e/b*c B)3*a*e/b/c C)a/b/c*e*3 D)a*e/c/b*334.下面程序的运行结果是DMain( ){struct cmplx{ int x;int y;}cnum[2]={1,3,2,7};Printf(“%d\n”,cnum[0].y/cnum[0].x*cnum[1].x);}A)0 B)1 C)3 D)635.若有以下说明和语句,且0<=i<10,则()是对数组元素的错误引用Cint a[]={1,2,3,4,5,6,7,8,9,0},*p,i;p=a;A)*(a+i) B)a[p-a] C)p+i D)*(&a[i])36.设有以下宏定义:C#define M 2#define X(m) ((M+2)*m)则执行语句:z=2*(M+X(3+2));后,z的值为A)44 B)45 C)32 D)3337.在如下程序段中的while循环Bint k=0;While(k=1) k++;A)有语法错,不能执行B)无限循环C)一次都不执行D)执行一次38.下列程序运行的结果为D#include<stdio.h>Main(){ int k=0;Char c=’A’;Do{switch(c++){ case ‘A’:k++;break;Case ‘B’:k- -;break;Case ‘C’:k+=2;break;Case ‘D’:k=k%2;break;Case ‘E’:k=k*10;break;Default:k=k/3;}K++;}while(c<’G’);Printf(“k=%d”,k);}A)k=4 B)k=6 C)k=7 D)k=839.下列程序运行的结果为C#include<stdio.h>fun(int x,int y,int *cp,int *dp){*cp=x+y;*dp=x-y;}main(){ int a,b,c,d ;a=30 ;b=50;fun(a,b,&c,&d);printf(“%d,%d\n”,c,d);}A)50,30 B)30,50 C)80,-20 D)80,2040.阅读程序回答问题:main( ){ int i,j,k,m=0;for(i=1;i<4;i++)for(j=1;j<4;j++)for(k=1;k<4;k++)m++;printf(“M=%d”,m);}以上程序输出M=( ). DA)3 B)6 C)9 D)2741.能将高级语言编写的源程序转换为目标程序的是CA)链接程序B)解释程序C)编译程序D)编辑程序42.以下4组用户定义标识符中,全部合法的一组是AA)main B)If C)txt D)intenclude -max REAL k_2sin turbo 3COM _00143.设有以下定义int a=0;double b=1.25;char c=’A’;#define d 2则下面语句中错误的是()DA)a++ B)b++ C)c++ D)d++;44.以下4个选项中,不能看作一条语句的是DA){;} B)a=0,b=0,c=0 C)if(a>0) D)if(b==0) m=1;n=2;45.有以下程序main( ){ char k; int i;for(i=1;i<3;i++){ scanf("%c",&k);switch(k){ case '0': printf("another\n");case '1': printf("number\n");}}}程序运行时,从键盘输入:01<回车>,程序执行后的输出结果是CA)another B)another C)another D)numbernumber number number numberanother number46.有以下程序void f(int v , int w){ int t;t=v;v=w;w=t;}main( ){ int x=1,y=3,z=2;if(x>y) f(x,y);else if(y>z) f(y,z);elsef(x,z);printf("%d,%d,%d\n",x,y,z);}执行后输出结果是CA)1,2,3 B)3,1,2 C)1,3,2 D)2,3,147.有以下程序段Dint a[10]={1,2,3,4,5,6,7,8,9,10},*p=&a[3],b;b=p[5];b中的值是A)5 B)6 C)8 D)948.有以下程序A#define f(x) x*xmain( ){ int i;i=f(4+4)/f(2+2);printf("%d\n",i);}执行后输出结果是A)28 B)22 C)16 D)449.设有以下语句typedef struct S{ int g; char h;}T;则下面叙述中正确的是BA)可用S定义结构体变量B)可以用T定义结构体变量C)S是struct类型的变量D)T是struct S类型的变量50.有以下程序Cint a=2;int f(int *a){return (*a)++;}main( ){ int s=0;{ int a=5;s+=f(&a);}s+=f(&a);printf("%d\n",s);}执行后输出结果是A)10 B)9 C)7 D)851.组成C程序的基本单位是AA)函数B)标识符C)表达式D)语句52.设int类型的数据长度为2字节,则该类型数据的取值范围DA)0至65536 B)0至65535 C)-32767至32768 D)-32768至3276753.在C语言中,逻辑值“真”是用( )表示的。
P173习题8 第一题#include<stdio.h>int main(void){char ch;int a[10];int i,j,m;printf("请输入10个整数:\n");for(i=0;i<10;i++){printf("请输入%d第个数:",i+1);scanf("%d",&a[i]);}printf("请输入A或D:");scanf(" %c",&ch);if(ch=='A'){for(i=0;i<9;i++){for(j=i+1;j<10;j++){if(a[i]>a[j]){m=a[i];a[i]=a[j];a[j]=m;}}}}else if(ch=='D'){for(i=0;i<9;i++){for(j=i+1;j<10;j++){if(a[i]<a[j]){m=a[i];a[i]=a[j];a[j]=m;}}}}for(i=0;i<10;i++){printf("%d ",a[i]);}return 0;}第二题#include<stdio.h>int main(void){int a[10];int i,j,x;int search(int list[],int i,int x);printf("输入10个整数:");for(i=0;i<10;i++)scanf("%d",&a[i]);printf("输入一个整数x:");scanf("%d",&x);j=0;for(i=0;i<10;i++){if(search(a,i,x)!=-1){j++;printf("%d",search(a,i,x));}else;}if(j==0)printf("-1");return 0;}int search(int list[],int i,int x){int j;j=0;if(x==list[i])j++;else;if(j==0)return -1;elsereturn i;}第三题#include<stdio.h>void houyi(int a[],int *p,int n,int m);int main(void){int a[20];int i,m,n;printf("请输入整数n:");scanf("%d",&n);printf("请输入%d个整数:",n);for(i=0;i<n;i++)scanf("%d",&a[i]);printf("请输入您要后移的位数m:"); scanf("%d",&m);houyi(a,a,n,m);for(i=0;i<n;i++)printf("%d",a[i]);printf("\n");return 0;}void houyi(int a[],int *p,int n,int m) {int i;int b[20];for(i=0;i<n;i++)b[i]=a[i];for(i=0;i<n;i++){if(i<=n-m-1)*(p+i+m)=b[i];else*(p+(i+m)%n)=b[i];}}第四题#include<stdio.h>void swap2(int *,int *);void bubble(int a[],int n);int main(void){int n,a[8];int i;printf("Enter n(n<=8):");scanf("%d",&n);printf("Enter a[%d]:",n);for(i=0;i<n;i++)scanf("%d",&a[i]);bubble(a,n);printf("After sorted,a[%d]=",n);for(i=0;i<n;i++)printf("%3d",a[i]);return 0;}void bubble(int a[],int n){int i,j,m;static int b[8];for(i=1;i<n;i++){for(j=0;j<n-i;j++){if(a[j]>a[j+1])swap2(&a[j],&a[j+1]);for(m=0;m<n;m++){if(a[m]<=a[m+1])b[m]++;}}if(b[m]==n-1)break;}}void swap2(int *px,int *py){int t;t=*px;*px=*py;*py=t;}第五题#include<stdio.h>#include<string.h>void mcopy(char *s,int m);int main(void){int i,m,l;char str[100];printf("请输入您要输入的字符串:");gets(str);printf("您将从原字符串的第m位复制新字符串,请输入m:\n");scanf("%d",&m);printf("复制后,新的字符串为:");mcopy(str,m);return 0;}void mcopy(char *s,int m){printf("%s\n",s+m-1);}第六题#include<stdio.h>#include<string.h>void delchar(char *,char c);int main(void){char str[80];char ch;printf("Enter a string:");gets(str);printf("Enter delete char:");scanf("%c",&ch);delchar(str,ch);printf("%s\n",str);return 0;}void delchar(char *s,char c){int i,j;char str1[80];j=0;for(i=0;s[i]!='\0';i++){if(s[i]!=c){str1[j]=s[i];j++;}}str1[j]='\0';for(i=0;str1[i]!='\0';i++,s++){*s=str1[i];}*s='\0';}第七题#include<stdio.h>#include<string.h>struct zfc{char str[80];};int main(void){int i,j;char str[80],str1[80];struct zfc s[5];for(i=0;i<5;i++){printf("请输入第%d个字符串:",i+1);scanf("%s",s[i].str);}for(i=0;i<=3;i++){for(j=i+1;j<=4;j++){if(strcmp(s[i].str,s[j].str)>0){strcpy(str1,s[i].str);strcpy(s[i].str,s[j].str);strcpy(s[j].str,str1);}}}for(i=0;i<5;i++){puts(s[i].str);}return 0;}第八题#include<stdio.h>#include<string.h>int main(void){int l,i;char str[80],str1[80];char *p,*q;p=str;q=str1;printf("请输入一串字符:");scanf("%s",str);l=strlen(str);for(i=0;*p!='\0';p++,i++){*(q+l-1-i)=*p;}*(q+l)='\0';if(strcmp(str,str1)==0)printf("输入的字符串是“回文”!\n");elseprintf("输入的字符串不是“回文”!\n");return 0;}第九题#include<stdio.h>#include<string.h>int main(void){char str[80];char *p;p=str;int n1,n2,n3,n4,n5;printf("输入一行文字:");gets(str);n1=n2=n3=n4=n5=0;for(;*p!='\0';p++){if((*p>='A')&&(*p<='Z'))n1++;else if((*p>='a')&&(*p<='z'))n2++;else if(*p==' ')n3++;else if((*p>='0')&&(*p<='9'))n4++;elsen5++;}printf("大写字母字符的个数为:%d\n",n1);printf("小写字母字符的个数为:%d\n",n2);printf("空格字符的个数为: %d\n",n3);printf("数字字符的个数为: %d\n",n4);printf("其他字符的个数为: %d\n",n5);return 0;}第十题#include<stdio.h>#include<string.h>int strcomp(char s1[80],char s2[80]);int main(void){int m;char str1[80],str2[80];printf("请输入第一个字符串:");scanf("%s",str1);printf("请输入第二个字符串:");scanf("%s",str2);m=strcomp(str1,str2);if(m==1)printf("str1>str2\n");else if(m==0)printf("str1=str2\n");elseprintf("str1<str2\n");return 0;}int strcomp(char s1[80],char s2[80]){int a;if(strcmp(s1,s2)>0)a=1;else if(strcmp(s1,s2)==0)a=0;elsea=-1;return a;}第十一题#include<stdio.h>#include<string.h>void fushu(char *p);int main(void){char str[80];printf("请输入一个英语名词单词:");scanf("%s",str);fushu(str);puts(str);return 0;}void fushu(char *p){int i,l;l=0;for(i=0;*(p+i)!='\0';i++){l++;}if(*(p+l-1)=='y'){*(p+l)='e';*(p+l+1)='s';*(p+l+2)='\0';}elseif((*(p+l-1)=='s')||(*(p+l-1)=='x')||((*(p+l-2)=='c')&&(*(p+l-1)=='h'))||((*(p+l-2)=='s')&&(*(p+l-1 )=='h'))){*(p+l)='e';*(p+l+1)='s';*(p+l+2)='\0';}else if(*(p+l-1)=='o'){*(p+l)='e';*(p+l+1)='s';*(p+l+2)='\0';}else{*(p+l)='s';*(p+l+1)='\0';}}第十二题#include<stdio.h>#include<stdlib.h>int main(void){int i,j,a,n,sum,average;int *p;printf("Enter n:");scanf("%d",&n);if((p=(int*)calloc(n,sizeof(int)))==NULL){printf("Not able to allocate memory.\n");exit(1);}printf("您将输入%d个学生的成绩!\n",n);for(i=0;i<n;i++){printf("请输入第%d个学生的成绩:",i+1);scanf("%d",p+i);}sum=0;for(i=0;i<n;i++)sum=sum+*(p+i);average=sum/n;for(i=0;i<n-1;i++){for(j=i+1;j<n;j++){if(*(p+i)>*(p+j)){a=*(p+i);*(p+i)=*(p+j);*(p+j)=a;}}}printf("学生的平均成绩是:%d\n",average);printf("学生的最高成绩是:%d\n",*(p+n-1));printf("学生的最低成绩是:%d\n",*p);return 0;}。
C语言程序设计习题答案C 语言作为一门基础的编程语言,在计算机科学领域中具有重要地位。
通过做 C 语言程序设计的习题,我们可以更好地掌握这门语言的语法、逻辑和算法。
下面是一些常见 C 语言程序设计习题的答案及详细解析。
一、基础语法题例如:计算两个整数的和。
```cinclude <stdioh>int main(){int num1, num2, sum;printf("请输入第一个整数:");scanf("%d",&num1);printf("请输入第二个整数:");scanf("%d",&num2);sum = num1 + num2;printf("两数之和为:%d\n", sum);return 0;}```这道题主要考查了 C 语言中基本的输入输出和算术运算。
通过`scanf` 函数获取用户输入的两个整数,然后使用`+`运算符计算它们的和,最后使用`printf` 函数输出结果。
二、控制结构题比如:判断一个数是否为偶数。
```cinclude <stdioh>int main(){int num;printf("请输入一个整数:");scanf("%d",&num);if (num % 2 == 0) {printf("%d 是偶数\n", num);} else {printf("%d 是奇数\n", num);}return 0;}```在此题中,使用了`ifelse` 语句来判断输入的数除以 2 的余数是否为 0,如果余数为 0 则为偶数,否则为奇数。
三、数组与循环题像这样的题目:求一个整数数组中所有元素的平均值。
```cinclude <stdioh>int main(){int arr ={12, 34, 56, 78, 90};int size = sizeof(arr) / sizeof(arr0);int sum = 0;for (int i = 0; i < size; i++){sum += arri;}float average =(float)sum / size;printf("数组的平均值为:%2f\n", average);return 0;}```这里使用了循环遍历数组的每个元素,将它们累加求和,最后计算平均值并输出。
C语言程序设计-谭浩强-第三版-课后习题答案1.5请参照本章例题,编写一个C程序,输出以下信息:**************************Very Good!**************************解:mian(){printf(“**************************”);printf(“\n”);printf(“Very Good!\n”);printf(“\n”);printf(“**************************”);}1.6 编写一个程序,输入a、b、c三个值,输出其中最大值。
解:mian(){int a,b,c,max;printf(“请输入三个数a,b,c:\n”);scanf(“%d,%d,%d”,&a,&b,&c);max=a;if(max<b)max=b;if(max<c)max=c;printf(“最大数为:“%d”,max);}第三章3.6写出以下程序运行的结果。
main(){char c1=’a’,c2=’b’,c3=’c’,c4=’\101’,c5=’\116’;printf(“a%cb%c\tc%c\tabc\n”,c1,c2,c3);printf(“\t\b%c %c”,c4,c5);}解:aaㄩbbㄩㄩㄩccㄩㄩㄩㄩㄩㄩabcAㄩN3.7 要将"China"译成密码,译码规律是:用原来字母后面的第4个字母代替原来的字母.例如,字母"A"后面第4个字母是"E"."E"代替"A"。
因此,"China"应译为"Glmre"。
请编一程序,用赋初值的方法使cl、c2、c3、c4、c5五个变量的值分别为,’C’、’h’、’i’、’n’、’a’,经过运算,使c1、c2、c3、c4、c5分别变为’G’、’l’、’m’、’r’、’e’,并输出。
C语言程序设计课后习题1—8参考答案习题1参考答案一、简答题1、冯诺依曼计算机模型有哪几个基本组成部分?各部分的主要功能是什么?答:冯诺依曼计算机模型是由运算器、控制器、存储器、输入设备、输出设备五大功能部件组成的。
运算器又称算术逻辑部件,简称ALU,是计算机用来进行数据运算的部件。
数据运算包括算术运算和逻辑运算。
控制器是计算机的指挥系统,计算机就是在控制器的控制下有条不紊地协调工作的.存储器是计算机中具有记忆能力的部件,用来存放程序和数据.输入设备是用来输入程序和数据的部件。
输出设备正好与输入设备相反,是用来输出结果的部件。
2、简述计算机的工作原理。
答:计算机的工作原理可简单地概括为:各种各样的信息,通过输入设备,进入计算机的存储器,然后送到运算器,运算完毕把结果送到存储器存储,最后通过输出设备显示出来。
整个过程由控制器进行控制。
3、计算机软件系统分为哪几类?答:软件内容丰富,种类繁多,通常根据软件用途将其分为两大类:系统软件和应用软件。
系统软件是指管理、监控、维护计算机正常工作和供用户操作使用计算机的软件。
这类软件一般与具体应用无关,是在系统一级上提供的服务。
系统软件主要包括以下两类:一类是面向计算机本身的软件,如操作系统、诊断程序等。
另一类是面向用户的软件,如各种语言处理程序(像BC、VC等)、实用程序、字处理程序等。
在操作系统的基础上运行。
4、什么叫软件?说明软件与硬件之间的相互关系。
答:软件是指计算机程序及有关程序的技术文档资料。
两者中更为重要的是程序,它是计算机进行数据处理的指令集,也是计算机正常工作最重要的因素。
在不太严格的情况下,认为程序就是软件。
硬件与软件是相互依存的,软件依赖于硬件的物质条件,而硬件则需在软件支配下才能有效地工作.在现代,软件技术变得越来越重要,有了软件,用户面对的将不再是物理计算机,而是一台抽象的逻辑计算机,人们可以不必了解计算机本身,可以采用更加方便、更加有效地手段使用计算机。
本文由青青de爱昵贡献 doc文档可能在WAP端浏览体验不佳。
建议您优先选择TXT,或下载源文件到本机查看。
【单项选择题参考答案】 【1.1】答案: A 注释:int 是 C 语言的关键字 【1.2】答案: B 【1.3】答案:A 【1.4】答案:B 注释:include 是预处理命令;scanf 是函数 名;type 不是 C 语言的关键字. 【1.5】答案:D 【1.6】答案:D 【1.7】答案:A 【1.8】答案:A 注释: int 型表示整数 的范围是 -32768~ 32767. 【1.9】答案:D 注释:整型常量-1 在计算机中表示为补码 1111 1111 1111 1111,用十六进制显示这个 数时,最左边的 1 不会被解释为符号位,而 是与右边其它位共同转换为十六进制数. 【1.10】答案:B 注释: 长整型数 32768 在计算机内的表示是 1000 0000 0000 0000,以一般整型进行输出 时,此数恰是-32768 的补码. 【1.11】答案:C 注释: 长整型数 65539 在计算机内的表示是 0001 0000 0000 0000 0011, 以一般整型进行 输出时,仅将右侧 16 位二进制数转换为十 进制数. 【1.12】答案:A 注释: 语言中, 型的负数是采用补码表 C int 示的. 【1.13】答案:D 【1.14】答案:C 注释:变量 c 是字符型,可用字符常量为它 赋值.字符常量必须用单引号括起来,所以 B 是错误的;在单引号或双引号内的反斜线 '\'用于表示转义字符,A 选项在无引号时使 用反斜线是错误的;C 选项单引号内出现反 斜线表示它与后面的数字组成一个转义字 符;单引号只允许括起一个字符,D 选项在 单引号内出现 4 个字符,是错误的. 【1.15】答案:C 【1.16】答案:D 注释:空字符和空格符是不同的两个字符, 空格符的 ASCII 码值是 32, 空字符的 ASCII 值是 0. 【1.17】答案:A 【1.18】答案:B 【1.19】答案:A 【1.20】答案:C 【1.21】答案:B 注释:单纯从 C 语言语法来说,选项 B,C 都是正确的, 但是选项 C 中第一个运算的两 个对象都是整型常数, 其结果也是整型数 0, 最后的运算结果也就是 0 了. 【1.22】答案:C 【1.23】答案:A 注释:将条件表达式增加一个括号,此式变 为 anext 是 a[0]的地址, 引用其成员 n 再做前增 1 运算, 结果就是 2. 【1.80】答案:B 【1.81】答案:D 【1.82】答案:A 【1.83】答案:C 注释:联合变量 temp 的成员是占用同一存 储单元,它的长度是 4 个字节.266 的二进 制表示是 100001010,存放在存储单元的低 端两个字节,如下图: 高字节 00000001 低字节 0 0 0 0 1 0 1 0 引用 temp.ch 进行输出,只取最低的第一个 字节. 【1.84】答案:D 注释: 由于结构指针指向了结构数组的 0 号 元素, 所以表达式(p++)->m 的含义是先取出 m(变量 a 的地址) ,然后指针 p 加 1.表达 式*(p++)->m 的含义是先取出 m 的内容 (变 量 a 的值)然后指针 p 再加 1. , 表达式(*p).m 的含义是取出 m(变量 a 的地址) .表达式 *(++p)->m 的含义是先将指针 p 加 1,然后 再取 m 的内容(变量 b 的值) . 【1.85】答案:D 【1.86】答案:B 【1.87】答案:C 【1.88】答案:A 【1.89】答案:D 【1.90】答案:D 【1.91】答案:A 【1.92】答案:B 【1.93】答案:A 【1.94】答案:D 注释: 函数 fopen 中的第二参数是打开模式, "r"模式是只读方式,不能写文件;"a+"模式 是读/追加方式,允许从文件中读出数据, 但所有写入的数据均自动加在文件的末尾; "w"模式是写方式,允许按照用户的要求将 数据写入文件的指定位置,但打开文件后, 首先要将文件的内容清空."r+"模式是读/ 写方式,不但允许读文件,而且允许按照用 户的要求将数据写入文件的指定位置, 且在 打开文件后,不会将文件的内容清空.本题 的要求是"修改"文件的内容,因此只能选择 答案 D. 【1.95】答案:C 【1.96】答案:D 【1.97】答案:C 【1.98】答案:B 注释:语句 z=2*(N+Y(5+1)引用了两个宏定 义.C 语言是区分字母大小的,第二个宏定 义中的 N 直接用 3 替换,用 5+1 替换 n,则 有 z=2*(3+(3+1)*5+1);结果是 48.注意对 于带参数的宏亦是直接的文本替换, 此例中 n 用 5+1 去替换,结果是(N+1)*5+1,而 不是(N+1)*(5+1). 【1.99】答案:C 注 释 : 宏 替 换 后 的 结 果 是 printf("%d",10/3*3). 【1.100】答案:C 【阅读程序题参考答案】 【2.1】参考答案:D 注释: 程序中除法运算的两个操作数均是整 型,运算结果也是整型. 【2.2】参考答案:B 注释:C 语言允许在程序块(分程序)中说明 变量. 【2.3】参考答案:C 注释:变量 i 中的负号传送给变量 n 后,因 n 是无符号数,已不作为负号处理. 【2.4】参考答案:D 注释:对变量 x 的――操作是后缀形式,变 量 x 的减 1 操作要在执行完 printf 函数之后 才进行, 所以变量 x 的值在输出的时候仍然 保持原值 10. 【2.5】参考答案:B 注释:C 语言在执行 printf()时,对函数中的 表达式表列的处理顺序是从后向前, 即先处 理 n- -,再处理 n++,最后处理 n,而且每 一个表达式作为一个处理单元, 也就是说在 不同的表达式中自增自减运算是单独考虑 的. 【2.6】参考答案:A 注释:变量 x 和变量 y 做按位与,结果为 0x0200,右移 4 位为 0x0020,再与 0x005f 做按位或,最后结果为 0x007f. 【2.7】参考答案:A 注释: 逗号表达式的结果是用逗号分开的最 后一个表达式的值, 此题由于 c=='A'的值是 0,所以逗号表达式的值为 0. 【2.8】参考答案: B 【2.9】参考答案: A 【2.10】参考答案: C 注释:在输出格式描述"%m.ns"中,m 是输 出总长度,n 是实际字符的个数,这里 m 没 有给出, 则输出总长度就是实际输出字符的 个数. 【2.11】参考答案: C 【2.12】参考答案:B 【2.13】参考答案:C 【2.14】参考答案:B 【2.15】参考答案:D 【2.16】参考答案:A 【2.17】参考答案: C 【2.18】参考答案:A 【2.19】参考答案: C 注释:在 switch 语句中,case 本身仅起到语 句标号的作用,不会改变语句的流程,执行 break 语句才能退出当前的 switch 语句. 【2.20】参考答案: D 注释:siwtch 语句的表达式中,变量 c 是后 缀的增一运算,第一次执行 do-while 循环 时,执行 case 'A'后面的语句. 【2.21】参考答案: D 【2.22】参考答案: B 【2.23】参考答案: B 注释:fabs()是浮点数绝对值函数. 【2.24】参考答案: A 【2.25】参考答案: C 注释:C 语言允许在程序块(分程序)内说 明变量, 如果在程序块内说明的变量和程序 块外的变量同名, 在块外说明的变量在块内 是不可见的.可将此题和【2.11】进行比较, 加深理解. 【2.26】参考答案: C 【2.27】参考答案: B 【2.28】参考答案: ① D ② A 【2.29】参考答案:D 【2.30】参考答案: B 注释:输出结果为字符串长度. 【2.31】参考答案: D 注释:字符串拷贝函数 strcpy()要求的两个 参数都是字符串首地址. 本题中第二个参数 是字符串常量, 接受这个字符串的第一个参 量不是直接给出字符数组名, 而是进行了地 址运算后的结果.由于 str 字符串的长度是 13,除 2 取整后是 6,第一个参数给出的地 址是字符数组 str 的首地址加 6, 也就是原来 字符串中第二个空格的位置, 把"es she"从该 处放入,字符串 str 变为"How does she". 【2.32】参考答案: C 注释:main 函数调用 func 函数时,第一个 实参使用的是逗号表达式的值,也就是 x+y 的结果.由于对变量 x,y,z 进行的是后缀 运算,所以函数 func 的参数值是 13 和 8. 【2.33】参考答案: C 【2.34】参考答案: ① C ② A ③ C 【2.35】参考答案: C 【2.36】参考答案: B 注释:函数 fun 进行了递归调用,实际进行 的运算是 5×4×3×2×1×3×10. 主函数内 说明的局部变量 w 屏蔽了外部变量 w, 所以 在主函数中外部变量 w 是不可见的, 在调用 printf 函数时表达式"fun(5)*w"中 w 的值是 10. 【2.37】参考答案: D 注释:main 函数三次调用了函数 funa,在 funa 函数中的静态变量 c 仅在第一次调用时 进行了初始化, 再次调用时不再对静态变量 赋初值. 【2.38】参考答案: B 注释:main 函数和 num 函数中都说明了变 量 a 和 b,由于它们是内部变量,所以它们 分别在说明它们的函数内有效.外部变量 x 和 y 在函数 num 之后被说明,而在 num 函 数中又要引用它们,所以在 num 函数中用 关键字"extern"说明变量 x 和 y 是一个外部 变量,也就是通知计算机这两个变量在 fun 函数以外被说明,此处不是定义两个 int 型 变量. 【2.39】参考答案: D 注释:函数 f 中的变量 c 是静态变量,仅在 第一次调用函数 f 时它被初始化为 3,第二次 调用函数 f 时 c 的值是 4,第三次调用函数 f 时 c 的值是 5. 【2.40】参考答案: D 【2.41】参考答案: D 注释:程序中有三个"x"分别在三个不同的 函数中,这三个"x"都是自动变量,所以三 个"x"分别局部于三不同的函数,在三个函 数中对"x"的操作互不影响. 【2.42】参考答案: A 【2.43】参考答案: A 注释: *(++p)和*++p 都是指针变量值前加 1, 第一次指向 a[1],第二次指向 a[2];a+3 是 a[3]的地址. 【2.44】参考答案: C 注释:②句没有语法错误,但是 a+6 指向数 组之外,因为 a 是 a[0]的地址,a+1 是 a[1] 的地址,a+2 是 a[2]的地址,显然数组 a 没 有 a[6]分量.③句错误,因为 a[1]是地址常 量,它是 a[1][0]的地址,对于地址常量是不 可以进行赋值运算的. 【2.45】参考答案: ① D ② A 注释:如果 FMT 定义为"%x\n",则输出的 16 进制数据用小写字母表示. 【2.46】参考答案: A 注释:语句"p=&a[0]"表示将数组 a 中元素 a[0]的地址赋给指针变量 p,则 p 就是指向 数组首元素 a[0]的指针变量, "&a[0]"是取数 组首元素的地址.对于指向数组首址的指 针,p+i(或 a+i)是数组元素 a[i]的地址, *(p+i)(或*(a+i))就是 a[i]的值. 【2.47】参考答案: B 【2.48】参考答案: D 【2.49】参考答案: D 【2.50】参考答案: A 注释:变量 g 是指向函数的指针,(*g)(a,b) 是调用指针 g 所指向的函数. 【2.51】参考答案: C 注释:p 是指针,pp 是指向指针的指针. 【2.52】参考答案: A 注释: 对于指向数组的指针变量可以做下标 运算,p[i]和 alpha[i]都是指向字符串的首地 址,*p[i]取出字符串的第一个字符. 【2.53】参考答案: ① D ② A ③ D ④ D ⑤ B 注释:pp 是一个二维指针数组,pp+1 指向 数组的第二维,*(pp+1)是第二维的起始地 址,**(pp+1)是第二维第一个元素的地址, ***(pp+1)是第二维第一个元素的内容,所 以,①的参考答案应选 D.*(pp+1)+1 是第 二维第二个元素的地址,*(*(pp+1)+1)是第 二维第二个元素,(*(*(pp+1)+1))[4]则是第 二维第二个元素所指字符串下标为 4 的元 素,即是字符 w,故③应当选 D. 【2.54】参考答案: ① B ② C 【2.55】参考答案:D 【2.56】参考答案:C 注释: 联合体成员的取值是最后一次给成员 赋的值. 【2.57】参考答案: B 注释:整型数组 i 和字符数组 c 共用存储空 间,给 i 赋值也等于给 c 赋值,所以 s->c[0]=0x39,所以输出 9. 【2.58】参考答案:A 注释:基本概念.EOF 是由 C 语言在头文 件 stdio.h 中定义的,用户可以直接使用. 【程序填空题参考答案】 【3.1】答案: ① a+b ② a-b ③ a-b 【3.2】答案:① 1.0/(float)(i*i) ② sqrt(6*s) 【3.3】答案:① *k=p 【3.4】答案:① t=t*i ② t=t>0?-1:1 【3.5】答案:① d=1 ② k++ ③ k<=n 【3.6】答案: ① x>=0 ② x0 ③ m=m/10 【3.9】答案:① i==j ② k!=i&&k!=j 【3.10】答案:① i<=9 ② j%3!=0 【3.11】 答案: m=n ② r!=0 ③ return(n) ① 【3.12】答案:① float a[10],x ② i<=9 ③ i<=8 ④ j<=9-i ⑤ a[j]>a[j+1] ⑥ a[j]=a[j+1] ⑦ i<=9 ⑧ i%5==0 【3.13】答案:① &a[i] ② continue 注释:①是基本概念,使用 scanf 函数输入 数组元素的值.当输入的元素值小于 0 时, 应当跳过后面的语句,取下一个数,所以② 要填入 continue. 【3.14】答案:① s[j++]=s[i] ② s[j]=s[i] 【3.15】答案:① s[j++]=s[i] 【3.16】答案:① x[i++] 【3.17】答案:① i=strlen(a);i>=j;i-- ② a[i+1]=a[i] 【3.18】答案:① '\0' ② str1[i]-str2[i] 【3.19】答案:① j++ ② '\\' ③ j++ ④ '\\' ⑤ j++ ⑥ '\0' 【3.20】答案:① t[k]!= '\0' ② t[k]== '\0' 【3.21】 答案: <=n ② s ③ 0 ④ fun(k) ① 【3.22】答案:① a[fmax(a,N)] ② k=p 【3.23】 答案: last*n%1000 ② x!=min-x ① ③ flag=0 【3.24】答案:① (x0+a/x0)/2 ② a,x1 注释:根据迭代公式,①处应当是计算迭代 值 x1=(x0+a/x0)/2.按照求平方根的要求, 当 迭 代 的 精 度 不 能 满 足 "(fabs(x1-x0)>0.00001)"时,则要继续迭代, 因此②处应当填写"a,x1".程序中调用了求 绝对值的库函数 fabs( ). 【3.25】答案:① 2+age(n-1) ② age(5) 注释:由于程序是递归算法,因此首先要建 立问题的递归数学模型. 根据原题的描述可 以写出如下递归公式: age(n) = 10 (n=1) age(n) = 2+age(n-1) (n>1) 对照程序和递归公式可以看出:n 的含义是 第 n 位学生.很显然,要求第 5 位学生的年 龄,②处应当是调用函数 age,实参的值应 当是 5.在①处应该是函数的递归调用,根 据递归公式,应当填写:2+age(n-1). 【 3.26 】 答 案 : ① return(1) ② return (sum(n-1)+n) 注释:按照常规的编程方法,此问题可采用 一个循环语句实现.阅读程序,没有发现循 环语句,这时,应当认为原来的编程者使用 的是非常规的算法. 对于这样常规算法需要 用循环实现而没有使用循环的程序, 就可以 肯定地认为,一定是使用了递归算法. 将问题"求1~n 的累加和"的公式写 成递归定义,可以是如下形式; sum(n)=1 当 n=1 时 sum(n)=sun(n-1)+n 当 n>1 时 根据此递归定义,可以很容易完成程序. 【3.27】答案:① return(1) ② n*facto(n-1) 注释: 我们熟悉的求 n!的算法一般是采用循 环语句实现, 但在此程序中根本没有循环语 句.这时我们应该想到:是采用递归算法实 现的.首先写出求 n!的递归公式; n!=1 当 n=1 时 n!=n*(n-1) 当 n>1 时 根据此递归定义,可以很容易完成程序. 【 3.28 】 答 案 : ① com=n ② com=combin(n-1,m-1) + combin(n-1,m) 注释: 题目的说明中已经给出组合问题的递 归定义,不需要读者自己寻找递归表达式. 程序中的语句"if (n<2*m) m=n-m;"完成了 题目中叙述的"用公式(1)进行简化"的工作. 【 3.29 】 答 案 : ① *str=='\0' ② 1+strlen(str+1) 注释: 求串长算法的关键是确定串结束标记 '\0'的位置.根据求串长的方法,可以得到如 下递归算法:指针 str 指向字符串的首字符 如果 当前字符(*str)== 串结束标记'\0' 则 串长=0 否则 串长 = 1+除第一个字符之外的剩余 字符串的串长 因此,在①的位置上应当填写"*str=='\0'", 以判断当前字符(*str)是否是串结束标记 '\0'. 在②的位置应当是根据上面的递归算法 进 行 递 归 调 用 , 因 此 应 当 填 写 "1+strlen(str+1)". 【3.30】 答案: &n ② m%10 ③ m/10 ④ ① m>0 ⑤ r(m) 【3.31】答案:① prt(c, n-1) ② prt(' ' , n-i) ③ prt('*', i) 注释:函数 prt 的功能是输出 n 个字符 c. 【3.32】答案:① y(x, n-1) 注释:这显然是一个递归问题,首先要对原 来的数学函数定义形式进行变形, 推导出原 来函数的等价递归定义. 可以推导出原来函 数的递归定义如下. y(x,n)=x 当 n=0 时 y(x,n)=sqrt(x+y(x,n-1)) 当 n>0 时 【3.33】 答案: p-- ② *p='\0' ③ *p=c ④ ① p-- ⑤ *s++ 注释:在递归算法中,指针 s 指向字符串首 部要反向的字符,即要将指针 s 所指向的字 符与指针 p 所指向的字符串尾的字符('\0') 进行交换,在交换过程中,将尚没有交换的 字符串的中间部分作为一个整体, 进行递归 处理.程序中首先执行"c=*s",将首字符存 入临时变量;然后执行"*s=*p",将尾字符 存入串首; 执行"revstr(s+1)"是递归处理串的 中间部分,这时,在②处应当填入"*p='\0'", 即存入串结束标记. 这是这一程序中的关键 所在.在③处要完成将存在临时变量 c 中的 字符存入串尾的工作,应当填写"*p=c". 【3.34】答案:① str+1 ② return ①改为 n-2 【3.35】 答案: p>=q ② max=s ③ p,max ① ④ p+1,q ⑤ &array[0], &array[9] 注释: 本程序中的排序部分采用的是递归算 法.函数 sort 的两个形参的含义是:对指针 p 和指针 q 之间的数据进行排序.由语句 "for( s=p+1; s<=q; s++)"中指针 p 和指针 q 之间的关系可以得出:指针 p 不应在指针 q 之后,因此①处应填"p>=q",⑤处应填 "&array[0],&array[9]". 由于变量 max 是指向当前最大值的指针, 则 当找到新的最大值时, max 中保存的应该是 新的最大值的指针, 因此②处应填"max=s". 当调用函数 swap 交换两个变量值的时候, 要求实参是变量的地址,因此,③处应填 "p,max"将最大值存入指针 p 所指的单元. 由于问题的要求是"从大到小"排序,通过执 行一次函数 sort 使最大值已经放到了指针 p 所指的单元中,因此,下一遍排序的时候, 只要对指针 p 之后的元素进行即可, 所以④ 处应填"p+1,q". 【3.36】答案:① a+1 ② n%10+'0' 【3.37】答案:① s<t ② s++ ③ t-【3.38】答案;①*(p+4*i+j) 注释:p 是一个一级指针,赋值后保存二维 数组 a 的首地址,做加法运算加 1 时, 实际地 址增加一个它所指向的数据类型的长度. 在 C 语言中,多维数组在计算机中是按行存储 的, 所以在本题中要通过指针访问二维数组 中的数据,必须将二维下标转换为一维下 标. 【3.39】答案:① '\0' 或 0 ② ++ 注释:在 C 语言中,进行字符串处理时,必 须注意串结束标记'\0', 它是在进行串处理时 的最基本的要求,所以①中要填入'\0'.为了 使用 putchar 输出一个字符串,则必须有改 变指针的运算,这里只能使用++运算. 【3.40】答案:① p++ ② w[i+1]=w[i] 【3.41】答案:① && ② *a<*b ③ *a++, *b++ ④ == ⑤ != ⑥ '\0' ⑦ w=s ⑧ n++ ⑨ t=s[i];s[i]=s[j];s[j]=t; ⑩ s3[0] 【3.42】答案:① *++pa ② *++pa ③ *pa ④ return(total) ⑤ n<=2 || n>=MAXNUM+1 ⑥ num+n 【3.43】 答案: stu.name ② &stu.score ③ ① p->name ④ p->score 注释:这是结构中的最基本概念. 【 3.44 】 答 案 : ① struct student ② strcmp(stu[i].name,str)==0 ③ break 注释: 程序的主体是一个二重循环, 内层 for 循环完成查找学生的工作. ①处是进行结构 数组说明并初始化, 按照结构变量说明的格 式规定,应该填写:strcut student.②处为 if 语句的逻辑条件,应当是当查找到指定的 学生后输出学生的情况,因此应当填写: strcmp(stu[i].name,str)==0.③处应当将控制 退出内层的 for 循环,只能选择 break 语句. 【3.45】答案:① p+n ② gets(p->name) ③ p+n 注释: 本程序是通过函数完成对于结构数组 的输入和输出操作. 函数 data_in 和 data_out 十分相似, 都是通过结构指针 p 和结构指针 q 来操作结构数组的元素.由于指针 q 在两 个函数中的作用相同, 所以①和③填写的内 容也应该是相同的;由 for 语句中的循环终 止条件"p<q"可以看出, 应该指在数组的最 q 后一个元素之后, 所以①和③应当填入 p+n. ②应当完成姓名的输入工作,应当为 gets(p->name). 【3.46】答案:① j=i-1 ② > ③ j-- ④ j+1 ⑤ j+1 注释:程序的基本思想是:对于输入的第 i 个整数 num,从数组 array 中已有的元素中 倒序开始查找.若数组 array 中的第 j 个元 素的值大于 num,则将数组中的元素 j 向后 移动一个位置;否则,就应将 num 插入到 当前位置作为元素 j.因此,程序的基本设 计思想就是插入排序. 程序中内层的 for 循环完成查找插入位置的 工作,因此答案①,②和③有密切的关系, 要统一考虑.同样,程序中的答案④和⑤也 有密切的关系,要统一考虑. 【3.47】答案:① != '\n' ② p=top 【3.48】答案:① p1->next 【3.49】答案:① head ② p ③ p=head 注释: 程序在从键盘接受字符的同时就在建 立起链表, 所建立的链表本身就已经是反序 排列的, 因此在反序输出字符串的时候实际 只需沿着链表的第一个结点开始, 顺序操作 即可. 【3.50】答案:① return ② (struct data *) malloc(sizeof(struct data)) ③ input( ) ④ p!=NULL ⑤ p=p->next 【 3.51 】 答 案 : ① (struct student *) ② tail=tail->next ③ head 注释: ①malloc 函数的作用是在内存开辟指 定字节数的存储空间, 并将此存储空间的地 址返回赋给尾指针 tail,但是此地址为 void 型, 应将其强制转换为所要求的结构指针类 型. ②新开辟的结点的内存地址存于 tail 所指向 的已建立的链表的尾结点的结构成员 next, 新结点连入链表以后,尾指针 tail 应指向新 的结点. 【3.52】 答案: (struct student *) ② (struct ① list *) ③ return(head) 【3.53】答案:① FILE ② !feof(fp) 注释:FILE 是文件结构类型名.feof()是测 试文件结束标志的函数. 【3.54】答案:① "second.txt" ② fclose(fp) 【 3.55 】 答 案 : ① 3 ② !feof(f1) 或 feof(f1)==0 ③ f2 ④ fclose(f2) ⑤ fclose(f1) 注释:程序中使用了带参数的 main 函数, 其中整型参数 argc 为命令行中字符串的个 数, 此程序运行时输入的字符串有可运行程 序名, 文件 1 和文件 2, argc 不应小于 3. 故 字符串指针 argv[0]指向可运行程序名, 字符 串指针 argv[1]指向输入文件名, 字符串指针 argv[2]指向输出文件名,由上所述②处给出 循环条件是输入文件是否结束, ③处需要填 出输出文件名.最后两处是关闭两个文件, 原则上关闭文件没有顺序要求, 但习惯上是 后打开的文件先关闭. 【3.56】答案:① *argv[1] ② (*funcp)(n) ③ s+=i 注释: 程序执行时输入的命令及参数的个数 (操作系统规定用空格表示字符串的分隔) 由系统赋给主函数的形数 argc,输入的命令 和参数以字符串的格式保存, 字符串的首地 址分别赋给指针数组 argv 的各个元素, 其中 argv[1]是'+'或'-',分别表示累加或阶乘.程 序根据 argv[1]所指向的字符串的内容给指 向函数的指针变量 funcp 赋值.②处要求的 语句是根据指向函数的指针变量的内容对 相应的函数实现调用,所以选择 A 或 B 是 错误的; funcp 是被调函数的地址, 据 *funcp 实现了对函数的调用,根运算符的结合性, (*funcp)表示取 funcp 的目标,而*funcp(n) 则 funcp 先和(n)结合,funcp 就被解释为函 数名,显然是错误的. 【3.57】答案:① "w" ② -32 ③ "r" 【3.58】答案:① "bi.dat" ② &j ③ fp 【 3.59 】 答 案 : ① fgetc(fp))!=EOF ② &keyword[i].word[0] ③ s++ ; q++ ; ④ *s==*q ⑤ (word=getword(cp))!=NULL 【 3.60 】 答 案 : ① "a+" ② rewind(fp) ③ !=NULL ④ flag=0 ⑤ ferror(fp)==0 【编写程序题参考答案】 【4.1】参考答案: #include main( ) { int year; float money,rate,total; /* money:本金 rate: 月利率 total:本利合计*/ printf("Input money and year =?"); scanf("%f%d", &money, &year); /* 输入本 金和存款年限 */ if(year==1) rate=0.00315; /* 根据年限确定 利率 */ else if(year==2) rate=0.00330; else if(year==3) rate=0.00345; else if(year==5) rate=0.00375; else if(year==8) rate=0.00420; else rate=0.0; total=money + money * rate * 12 * year; /* 计算到期的本利合计 */ printf(" Total = %.2f\n", total); } 【4.2】参考答案: #include main( ) { int year, month, days; printf("Enter year and month:"); scanf("%d%d", &year, &month); switch (month) { case 1: case 3: case 5: case 7: case 8: case 10: case 12: days=31; break; /* 处理"大"月 */ case 4: case 6: case 9: case 11: days=30; break; /* 处理"小"月 */ case 2: if(year%4==0&&year%100!=0 || year%400==0) days=29; /* 处理闰年平月 */ else days=28; /* 处理不是闰年平月 */ break; default: printf("Input error!\n"); /* 月份错误 */ days=0; } if( days!=0 ) printf("%d, %d is %d days\n", year, month, days); } 【4.3】参考答案: #include main ( ) { float data1, data2; /* 定义两个操作数变 量 */ char op; /* 操作符 */ printf("Enter your expression:"); scanf("%f%c%f", &data1, &op, &data2); /* 输入表达式 */ switch(op) /* 根据操作符分别进行处理 */ { case '+' : /* 处理加法 */ printf("%.2f+%.2f=%.2f\n", data1, data2, data1+data2); break; case '-' : /* 处理减法 */ printf("%.2f-%.2f=%.2f\n", data1, data2, data1-data2); break; case '*' : /* 处理乘法 */ printf("%.2f*%.2f=%.2f\n", data1, data2, data1*data2); break; case '/' : /* 处理除法 */ if( data2==0 ) /* 若除数为 0 */ printf("Division by zero.\n"); else printf("%.2f/%.2f=%.2f\n", data1, data2, data1/data2); break; default: /* 输入了其它运算符 */ printf("Unknown operater.\n"); } } 【4.4】分析:打印此图形用两重循环实现. 图形要重复 n 行, 故采用循环结构实现循环 n 次,循环体内部打印一行'*'号,把上述思路 表示为: for(i=1;i<=n;i++) 打印一行'*'号; 每行有 n 个'*'号,再采用循环结构实现 n 次 循环,循环内部用格式输出语句打印一个'*' 号,即: for(j=1;j<=n;j++) printf("*"); 按照上述思路,实现打印矩形. 参考答案: main() { int i,j,n; printf("\nPlease Enter n:"); scanf("%d",&n); for(i=1;i<=n;i++) { for(j=1;j<=n;j++) printf("*"); printf("\n"); } } 【4.5】 分析: 此图形和上题的区别在于在每 一行先要打印空格,然后再打印 n 个'*'号, 在上题第一层循环体内打印'*'号的循环前 面增加一个循环打印空格. 每行空格的个数 是逐行减少的, 由于第一层循环的控制变量 i 是逐行增 1,所以用一个固定值的数减去 i 就可实现对空格个数的控制, 在此题中固定 值可使用变量 n. 参考答案: main( ) { int i,j,n; printf("\nPlease Enter n:"); scanf("%d",&n); for(i=1;i<=n;i++) { for(j=1;j<=n-i;j++) printf(" "); for(j=1;j<=n;j++) printf("*"); printf("\n"); } } 【4.6】分析:此题和上题的区别在于每行'*' 的数量逐行减少, 可以使用上题控制空格个 数的思路来控制'*'号的个数,请注意每行'*' 的个数都是奇数. 参考答案: main( ) { int i,j,n; printf("\nPlease Enter n:"); scanf("%d",&n); for(i=1;i<=n;i++) { for(j=1;j<=n-i;j++) printf(" "); for(j=1;j<=2*i-1;j++) printf("*"); printf("\n"); } } 【4.7】 分析: 此题图形是第 3 题图形的垂直 反转,在编程上我们可以变换一个思路.对 于图形中的第 i 行(1≤i≤n) ,共需要输出 2n-i 个字符, 其中前面的 i-1 个字符为空格, 后面的字符为'*'号.按照这一思路可以编写 出如下程序. 参考答案: main( ) { int i,j,n; printf("\nPlease Enter n:"); scanf("%d", &n); for( i=1;i<=n;i++ ) /* 重复输出图形的 n 行 */ { for( j=1;j<=2*n-i;j++ ) /* 重复输出图形 一行中的每个字符 */ if(j<=i-1) printf(" "); /* 输出前面的空格 */ else printf("*"); /* 输出后面的*号 */ printf("\n"); } } 【4.8】 分析: 此题和第 3 题的区别仅是每行 的'*'个数增加 n-1 个. 参考答案: main( ) { int i,j,n; printf("\nPlease Enter n:"); scanf("%d",&n); for(i=1;i<=n;i++) { for(j=1;j<=n-i;j++) printf(" "); for(j=1;j<=2*i-1+(n-1);j++) printf("*"); printf("\n"); } } 【4.9】分析:对于空心图形,我们可以在上 题的基础上,对于打印'*'号的循环进行修 改 , 仅 在 循 环 开 始 值 (j=1) 和 循 环 结 束 值 (j=2*(i-1)+n)时打印'*'号, 其它位置都打印空 格.另一种思路是将每行打印的空格和'*' 的两个循环合为一体考虑, 在判断出需要打 印'*'的两个位置及第一行和最后一行相应 位置外,其余位置都打印空格. 参考答案: main( ) { int i,j,n; printf("\nPlease Enter n:"); scanf("%d",&n); for(i=1;i<=n;i++) { for(j=1;j<=2*n+i-3;j++) if(j==n-i+1 || j>n-i+1 && (i==1||i==n)) printf("*"); else printf(" "); printf("*\n"); } } 【4.10】分析:此图形可以理解为两个空心 梯形反向连接而成, 因此可以利用上题的思 路进行输出. 参考答案: main( ) { int i,j,n; printf("\nPlease Enter n:"); scanf("%d",&n); for(i=1;i<=n;i++) /* 输出图形的上半部分 (含中心行) */ { for(j=1;j<=2*n-i-1;j++) if(j==i) printf("*"); else printf(" "); printf("*\n"); } for(i=1;i<n;i++) /* 输出图形的下半部分 (不含中心行) */ { for(j=1;j<=n+i;j++) if(j==n-i) printf("*"); else printf(" "); printf("*\n"); } } 【4.11】分析:此题与上题的区别在于打印 '*'号的位置不同,编程时要找出应打印'*'号 的位置和两个循环变量 i, 以及行数 n 的关 j 系. 参考答案: main( ) { int i,j,n; printf("\nPlease Enter n:"); scanf ("%d", &n); for(i=1;i<=n;i++) /* 输出图形的上半部分 (含中心行) */ { for(j=1;j<=2*n-i;j++) if(j==n-i+1 || j>n-i+1 && i==1) printf("*"); else printf(" "); printf("*\n"); } for(i=1;i<n;i++) /* 输出图形的下半部分 (不含中心行) */ { for(j=1;j<=3*(n-1)-i;j++) if(j==i+1 || j>i+1 && i==n-1) printf("*"); else printf(" "); printf("*\n"); } } 【4.12】参考答案: main( ) { int i,j,n; printf("\nPlease Enter n:"); scanf("%d",&n); for(i=1;i<=n;i++) { for(j=1;j<=n;j++) if(j==n-i+1 || i==1 || i==n) printf("*"); else printf(" "); printf("\n"); } } 【4.13】参考答案: main( ) { int i,j,n; printf("\nPlease Enter n: "); scanf("%d", &n); for(i=1;i<=n;i++) /* 输出图形的上半部分 (含中心行) */ { for(j=1;j<=n-i;j++) if(j==1 || j==n-i+1) printf("* "); else printf(" "); printf("\n"); } for(i=1;i<n;i++) /* 输出图形的下半部分 (不含中心行) */ { for(j=1;j<=i+1;j++) if(j==1 || j==i+1) printf("* "); else printf(" "); printf("\n"); } } 【4.14】参考答案: main( ) { int i,j,n; printf("\nPlease Enter n: "); scanf("%d",&n); for(i=1;i<=n;i++) { for(j=1;j<=n;j++) if(j==1 || j==i || j==n) printf("*"); else printf(" "); printf("\n"); } } 【4.15】参考答案: main( ) { int i,j,n; printf("\nPlease Enter n: "); scanf("%d",&n); for(i=1;i<=n;i++) { for(j=1;j<=n+i-1;j++) if(j>n-i) printf("*"); else printf(" "); printf("\n"); } for(i=1;i<n;i++) { for(j=1;j<=2*n-i-1;j++) if(j>i) printf("*"); else printf(" "); printf("\n"); } } 【4.16】参考答案: main( ) { int i,j,n; printf("\nPlease Enter n: "); scanf("%d",&n); for(i=1;i<=n;i++) { for(j=1;j<=n+i-2;j++) if(j==n-i+1) printf("*"); else printf(" "); printf("*\n"); } } 【4.17】分析:首先对图形进行设计,坐标 的 X 轴和 Y 轴分别对应屏幕的列和行,一 个正弦函数的周期为 0~360 度,我们把一 个步长定义为 10 度,打印时每换一行等于 函数的自变量增加 10 度; 屏幕的列宽为 80, 函数值为 0 对应屏幕的第 40 列,sin(x)的值 在-1~1,变换成列数为以 0 为中心的-30~ 30,对应屏幕上第 10~70 列.设计程序时, 控制换行的自变量 i 乘以 10 得到正弦函数 的 X 值,调用库函数 sin()求出函数值再乘 以 30 输出的列宽,因为我们以屏幕的第 40 列为 0 点,故再加上 40 得到应在屏幕上显 示的点. 参考答案: #define PAI 3.14159 #include <math.h> main( ) { double x; int y,i,yy; for(i=1; i<80; i++) /* 打印图形的第一行 */ if(i==40) printf("*"); /* i 控制打印的列位置 */ else printf("-"); printf("\n"); for(x=10.0;x<=360.0;x+=10.) /* 从 10 度 到 360 度 */ { y = 40+30*sin(x*PAI/180.0); /* 计算对应 的列 */ yy = 40>y ? 40 : y; /* 下一行要打印的字符 总数 */ for (i=1;i<=yy;i++) /* 控制输出图形中的 一行 */ { if(i==y) printf("*"); /* i 控制打印的列位 置 */ else if(i==40) printf("|"); /* 打印中心的竖 线 */ else printf(" "); } printf("\n"); } } 【4.18】分析:首先设计屏幕图形,如果预 计圆形在屏幕上打印 20 行,所以定义圆的 直径就是 20,半径为 10,圆的方程是 X2× Y2=R2,因为图形不是从中心开始打印而是 从边沿开始,所以 Y 从 10 变化到-10,根据 方程求出 X,对求得的 X 值再根据屏幕行宽 进行必要的调整得到应打印的屏幕位置. 参考答案: #include <math.h> main( ) { double y; int x,m; for(y=10;y>=-10;y--) /* 圆的半径为 10 */ { m = 2.5 * sqrt(100-y*y); /* 计算行 y 对应 的列坐标 m */ for(x=1;x<30-m;x++) printf(" "); /* 输出圆左侧的空白 */ printf("*"); /* 输出圆的左侧 */ for(;x<30+m;x++) printf(" "); /* 输出圆的空心部分 */ printf("*\n"); /* 输出圆的右侧 */ } } 【4.19】参考答案: #include #include <math.h> main( ) { double y; int x, m, n, yy; for( yy=0;yy<=20;yy++) { y = 0.1*yy; m = acos(1-y)*10; n = 45 * (y-1)+31; for( x=0;x<=62;x++ ) if( x==m && x==n ) printf("+"); else if(x==n) printf("+"); else if(x==m || x==62-m) printf("*"); else printf(" "); printf("\n"); } } 【4.20】分析:编程的关键为两点,一是使 用控制输出的行和列, 这方面的内容在前面 已经叙述,另一点是输出的数字和所在行, 列关系.此题第一行输出的数字恰好是列 数, 从第二行起每行的数字均比上一行增 n. 参考答案: main( ) { int i,j,n; printf("\nPlease Enter n: "); scanf("%d",&n); for(i=1;i<=n;i++) { for(j=1;j<=n;j++) printf("%4d",(i-1)*n+j); printf("\n"); } } 【4.21】分析:此题的关键是找到输出数字 和行,列数的关系.审查图形中每行中数字 的关系发现, 右边数字和前面数字之差逐次 增 1;同列数字依然是这样的关系,编程的 关键转换为找到每一行左方的第一个数字, 然后利用行和列的循环变量进行运算就可 得到每个位置的数字.用 ai,j 此表示第 i 行 第 j 列的数字,则 a11=1;由第 i 行第一列 的数字推出第 i+1 行第一列的数字是 ai+1,1 = ai,1+i;同样由第 j 列推出第 j+1 列的数字 是 ai,j+1 = ai,j+i+j. 另外只有当 j<i 时才输出 数字. 参考答案: main( ) { int i,j,m,n,k=1; /* k 是第一列元素的值 */ printf("Please enter m=" "); scanf("%d",&m); for(i=1;i<=m;i++) { n=k; /* n 第 i 行中第 1 个元素的值 */ for(j=1;j<=m-i+1;j++) { printf("%3d",n); n = n+i+j; /* 计算同行下一个元素的值 */ } printf("\n"); k=k+i; /* 计算下一行中第 1 个元素 */ } } 【4.22】参考答案: main( ) { int i,j,n; printf("\nPlease Enter n: "); scanf("%d",&n); for(i=1;i<=n;i++) { for(j=1;j<=n;j++) if(j<=i) printf(" 1"); else printf("%3d",j-i+1); printf("\n"); } } 【4.23】 分析: 可用不同的方案解决此问题, 为了开阔读者的思路, 这里给出了两个参考 答案,其中第二个答案是使用了递归方法. 方案一: 首先寻找数字输出数字和行列的关系. 每圈有四个边, 把每边的最后一个数字算为 下边的开始, 最外圈每边数字个数是 n-1 个, 以后每边比外边一边少两个数字. 因为数字是一行一行输出的, 再分析每行数 字的规律.实际没有的数字有三种规律:位 于对角线之间的数字是上半图增一, 下半图 减一.对角线左侧的各列,右侧比左侧增加 了一圈数字, 例如数字 39 和它左侧的 22 比 较,数字 39 所在的圈每边 4 个数字,左侧 22 加上一圈 16 个数字在加 1 就是 39. 同理, 对角线右侧的各列,则减少一圈的数字个 数. 根据以上分析, 用两个对角线将图形分为四 个区域,如下图所示,图中黑斜体字为对角 线上的数字. 1234567 24 25 26 27 28 29 8 23 40 41 42 43 30 9 22 39 48 49 44 31 10 21 38 47 46 45 32 11 20 37 36 35 34 33 12 19 18 17 16 15 14 13 为叙述方便我们称四个区域为上,下,左, 右区.设 i,j 为行列号,n 为图形的总行数, 则 满 足 各 区 的 范 围 是 , 上 区 : j>=i 且 j<=n-i+1 ; 下区:j<=i 且 j>=n-i+1 ;左区: ji 且 j>n-i+1 . 现在问题是, 如果知道一行在不同区域开始 第一个位置的数字, 然后该区后续的数字就 可利用前面分析的规律得到. 对于右区开始各行第一个数字最易求出, 为 4*(n-1)-i+1.后续一个和同行前一个数字之 差是 4*[n-1-(j-1)*2]+1,其中方括号内是每边 的数字个数. 对角线上的数字是分区点, 对角线上相临数 字仍然相差一圈数字个数, 读者自行分析得 到计算公式. 右区开始的第一个数字可以从上区结束时 的数字按规律求出. 下述程序用变量 s 保存分区对角线上的数 字. 参考答案一: main() { int i,j,k,n,s,m,t; printf("Please enter n:"); scanf("%d",&n); for(i=1;i<=n;i++) { s=(i<=(n+1)/2)? 1:3*(n-(n-i)*2-1)+1; m=(i<=(n+1)/2)? i:n-i+1;/* m-1 是外层圈数 */ for(k=1;k<m;k++) s+=4*(n-2*k+1); for(j=1;j<=n;j++) { if(j>=n-i+1 && j<=i) /* 下区 */ t=s-(j-(n-i))+1; if(j>=i && j<=n-i+1) /* 上区 */ t=s+j-i; if(j>i && j>n-i+1) /* 右区 */ t-=4*(n-2*(n-j+1))+1; if(j1) 若令:ai,j=fun(ai-1,i-1+4(N-2i-1),当:i< (N+1)/2 且 j<(N+1)/2 时,min=MIN(i,j),则 有: a2,2 = fun(a1,1, min, min, n) ai,j=fun(a2,2, i-min+1, j-min+1, n-2*(min-1) ) 我们可以根据上述原理,分别推导出 i 和 j 为其它取值范围时的 min 取值. 根据上述递 归公式,可以得到以下参考程序. 参考答案二: #include #define MIN(x,y) (x>y) ? (y) : (x) fun ( int a11, int i, int j, int n) { int min, a22; if( i==j && i<=1 ) return(a11); else if( i==j && i<=(n+1)/2) return( fun(a11,i-1,i-1,n)+4*(n-2*i+3)); else if( i==1 && j!=1) return( a11+j-1 ); else if( i!=1 && j==n) return( a11+n+i-2 ); else if( i!=1 && j==1 ) return ( a11+4*n-3-i ); else if( 。
第一部分习题篇第一章C语言概述一.单选题1.以下说法中正确的是(C)。
A)C语言程序总是从第一个函数开始执行B)在C语言程序中,要调用函数必须在main()函数中定义C)C语言程序总是从main()函数开始执行D)C语言中的main()函数必须放在程序的开始部分2.一个C语言程序是由(B)。
A)一个主程序和若干子程序组成B)函数组成C)若干过程组成D)若干子程序组成3.C语言规定,在一个源程序中,main函数的位置(C)。
A)必须在最开始B)必须在系统调用的库函数的后面C)可以任意D)必须在最后4.以下叙述不正确的是(D)。
A)一个C源程序可由一个或多个函数组成B)一个C源程序必须包含一个main函数C)C程序的基本组成单位是函数D)在C程序中,注释只能位于一条语句的后面5.下列关于C语言的说法不正确的是(D)。
A)C语言既有高级语言的功能,也具有低级语言的一些功能B)C语言中的一条执行语句都必须用分号结束C)注释可以出现在程序中任意合适的地方D)include命令行后面必须加分号6.用C语言编写的代码程序(B)。
A)可以立即执行B)是一个源程序C)经过编译即可执行D)经过编译解释才能执行7.用高级语言(如C语言)编写的程序称为(A)A)源程序B)目标程序C)可执行程序D)编译程序8.一个函数的组成有(A)。
A)函数首部和函数体B)函数名和函数的声明部分C)主函数和子函数D)声明部分和执行部分9.在C语言中,用来表示“取地址”的符号是(B)。
A)#B)&C)* D)@10.C语言是计算机高级语言,它适合于作为系统描述语言,它(A)。
A)既可用来写系统软件,也可用来写应用软件B)只能写系统软件,不能用来写应用软件C)不能写系统软件,只能用来写应用软件D)既不能写系统软件,也不能写应用软件二.填空题1.C语言用函数作为程序的模块单位,便于实现程序的模块化。
2.C语言允许直接访问物理地址,能进行位操作。
C语言程序设计习题集东华理工大学2014.9基础知识一单项选择题(每题2分,共44分)1 以下叙述正确的是___。
A C程序基本组成单位是语句B C程序每一行只能写一个语句C 简单C语句必须以分号作为结束符D 注释语句可以嵌套2 一个C语言程序是从___开始执行的。
A 程序中第一个函数B 名为main的函数C 包含文件(头文件)的第一个函数D 程序中的第一个语句3 请选出合法的C语言赋值语句___。
A a=b=58B i++;C a=58,b=58D k=int(a+b);4 下面标识符中,合法的用户标识符是___。
A 1abcB includeC a-b-c123D char5 以下所列的C语言整形常量中,正确的是___。
A 0x10B 0976C 076LD 01ff6 C语言中下列运算符的操作数必须为整型的是___。
A %B ++C /D =7 设a和b均为int型变量,则执行以下语句后的输出为___。
int a=20; int b=3; printf("%d\n",a+=(b%=2));A 20B 21C 0D 238 已知int i;,则执行语句 i=2.6;后,i的值为___。
A 2B 3C 2.6D 不确定9 以下合法的字符常量为___。
A 'ab'B '\482'C '\'D '\xaf'10 若y为int型变量,则执行以下语句后,y的值是___。
y=8; y+=y-=y*y;A 64B –56C –112D –4811 以下合法的浮点型常量是___。
A e-3B 1.5e+2.4C 3.14e+2LD 3.14 e +512 设int数据占用两个字节,float数据占用四个字节,double数据占用8个字节,且已知float a=2;int b=3;则执行下列语句输出为___。
printf("%d",sizeof(a*b)+2/5);A 4B 8C 6D 713 设int型占2个字节,且int i=-2;,则语句printf("%u",i);的输出结果为___。
实验三3.4编写程序,用getchar函数读入两个字符c1,c2,然后分别用putchar函数输出void main(){char c1,c2;c1=getchar();c2=getchar();putchar(c1);putchar(c2);putchar('\n');printf("%c %c\n",c1,c2);}3.5把790分钟换成用小时和分钟表示,然后输出。
void main(){int s=790;printf("%d小时",s/60);printf("%d分钟",s%60);}3.6将读入三个数a,b,c,然后交换它们的值,把a的值给b,把b的值给c,把c的值给a.main(){int a,b,c,t;scanf("%d,%d,%d",&a,&b,&c);t=a;a=b;b=c;c=t;printf("%d,%d,%d",a,b,c);3.7输入一个double类型的数,使该数保留小数点后两位,对第三位小数进行四舍五入处理,然后输出此数,验证处理是否真确。
#include<stdio.h>void main(){float x,s,a;int z;scanf("%f",&x);a=100*x+0.5;z=(int)(a);s=z/100.0;printf("%.2f\n",s); }main(){int a,b,t;double c;scanf("%lf",&c);b=100*c;t=1000*c;a=t%10;if (a>=5) b=b+1;else b=b+0;c=1.0*b/100;printf("%7.2lf/n",c); return 0;}void main(){int x,y;scanf("%d",&x);if(x<0&&x>-5) y = x ; if(x==0) y = x-1;if(x<10&&x>0) y = x+1; printf("%d",y);}实验四4.2不嵌套if语句void main(){int x,y;scanf("%d",&x);if(x<0&&x>-5) y = x ;if(x==0) y = x-1;if(x<10&&x>0) y = x+1;printf("%d",y);}法二:嵌套if语句void main(){int x,y;scanf("%d",&x);if((x>-5)&&(x<0)) y=x;else if(x==0) y=x-1;else if(x<10&&x>0) y=x+1;printf("%d",y);}4.3如下程序运用条件运算符求变量的绝对值?void main(){int a,M;scanf("%d",&a);M=a>0?a:-a;printf("abs(a)=%d",M);4.4某服装店经营套服,也可单件出售,若买的不少于50套,每套80元,不足50套的每套90元,只买上衣每件60元,只买裤子每条45元,(读入所买上衣C和裤子t的件数,计算应付款m。
《C语⾔程序设计》第4版何钦铭、颜晖主编课后习题答案第2章 ⽤C语⾔编写程序Page 0201#include<stdio.h>//练习2-32int main(void)3{4 int i,j,k;5 for(int i=1;i<=4;i++)//第i⾏6 {7 for(int j=1;j<=i-1;j++)//j个空格8 {9 printf(" ");10 }11 for(k=1;k<=5-i;k++)//k个*12 {13 printf("* ");14 }15 printf("\n");16 }1718 return 0;19}Page 0231#include<stdio.h>2int main(void)3{4 int f,c;//练习2-55 f=150;6 c=5*(f-32)/9;//或者是c=5/9.0*(f-32)||c=5.0/9*(f-32),但不可以是5/9,会得到0.因为:两个整型数据做除法运算,结果⼀定是整数。
7 printf("华⽒温度%d对应的摄⽒温度为%d.\n",f,c);89 printf("\n");1011 /*计算物体⾃由下落的距离(练习2-6)*/12 int h,g,t;13 t=3;//下落时间14 g=10;//重⼒加速度 10m/s^215 h=g*t*t/2;16 printf("⼀个物体从100⽶的⾼空⾃由下落,前3秒内下落的距离为:%d⽶.\n",h);1718 return 0;19}20Page 0292#include<math.h>3int main(void)4{5 /*计算摄⽒温度(练习2-8)*/6 double c,f;7 printf("输⼊华⽒温度:");8 scanf("%lf",&f);9 c=5*(f-32)/9.0;10 printf("华⽒温度%.2lf对应的摄⽒温度为%.3lf\n",f,c);1112 printf("\n");1314 /*整数四则运算(练习2-9)*/15 int x,y,z_1,z_2,z_3;16 double z_4;17 printf("输⼊两个正整数x,y:");18 scanf("%d %d",&x,&y);19 z_1=x+y;20 z_2=x-y;21 z_3=x*y;22 z_4=x/y;23 printf("%d和%d的和为%d,差为%d,积为%d,商为%lf\n",x,y,z_1,z_2,z_3,z_4); 2425 printf("\n");2627 /*计算分段函数(判断x是否不为0)(练习2-10)*/28 double x_1,y_1;29 printf("输⼊x_1:");30 scanf("%lf",&x_1);31 if(x_1!=0)32 y_1=1/x_1;33 else y_1=0;34 printf("输⼊%.2lf时,对应的y值为%.1lf\n",x_1,y_1);3536 printf("\n");3738 /*计算分段函数(判断x是否⼩于0)(练习2-11)*/39 double x_2,y_2;40 printf("输⼊x_2:");41 scanf("%lf",&x_2);42 if(x_2<0)43 y_2=pow(1+x_2,2)+2*x_2+1/x_2;44 else y_2=sqrt(x_2);45 printf("输⼊%.2lf时,对应的y值为%.2lf\n",x_2,y_2);464748 printf("\n");4950 return 0;51}Page 0372int main(void)3{4 int i,n,flag;//例2-85 double t,sum;6 printf("输⼊⼀个正整数n:");7 scanf("%d",&n);8 sum=0;9 flag=1;10 for(i=1;i<=n;i++)11 {12 t=flag*(1.0/(2*i-1));13 sum+=t;14 flag=(-1)*flag;1516 }17 printf("sum=%lf\n",sum);1819 printf("\n");2021 /*求1+1/2+···的前n项和(练习2-13)*/22 int n_1,j;23 double sum_1=0;24 printf("Enter n_1(n_1>=0):");25 scanf("%d",&n_1);26 for(j=1;j<=n;j++)27 {28 sum_1+=1.0/j;29 }30 printf("sum_1=%.2lf\n",sum_1);3132 printf("\n");3334 /*求1+1/3+1/5+···的前n项和(练习2-14)*/35 int n_2,k;36 double sum_2;37 printf("Enter n_2:");38 scanf("%d",&n_2);39 for(k=1;k<=n_2;k++)40 {41 sum_2+=1.0/(2*k-1);42 }43 printf("sum_2=%.2lf\n",sum_2);4445 printf("\n");4647 /*求1-1/4+1/7-1/10+···的前n项和(练习2-15)*/48 int n_3,m,flag_1=1;49 double sum_3=0;50 printf("Enter n_3:");51 scanf("%d",&n_3);52 for(m=1;m<=n;m++)53 {54 sum_3+=flag_1*1.0/(3*m-2);55 flag_1=flag_1*(-1);56 }57 printf("sum_3=%.2lf\n",sum_3);5859 return 0;60}Page 0402#include<math.h>3int main(void)4{5 int n,i;6 double power;7 printf("Enter n:");8 scanf("%d",&n);9 printf("2的乘⽅表:\n");10 for(i=0;i<=n;i++)11 {12 power=pow(2,i);13 printf("2的%d次⽅为%.0lf\n",i,power);14 }1516 printf("\n");1718 /*3的乘⽅表(练习2-17)*/19 int m,j;20 double power_1;21 printf("Enter m:");22 scanf("%d",&m);23 for(j=0;j<=m;j++)24 {25 power_1=pow(3,j);26 printf("pow(3,%d)=%.lf\n",j,power_1);27 }2829 return 0;30}1#include<stdio.h>//练习2-182double fact(int n)3{4 int i;5 double product;6 product=1;7 for(i=1;i<=n;i++)8 {9 product*=i;10 }1112 return product;13}14int main(void)15{16 int n,m,i;17 double result_1,result_2,result_3,c;18 printf("输⼊两个正整数m和n(m<=n):");19 scanf("%d %d",&m,&n);20 for(i=0;i<=n;i++)21 {22 result_1=fact(i);23 }24 for(i=0;i<=m;i++)25 {26 result_2=fact(i);27 }28 for(i=0;i<=n-m;i++)29 {30 result_3=fact(i);31 }32 c=result_1/(result_2*result_3);33 printf("c=%.lf",c);3435 return 0;36}。
第1章程序设计和C语言 1 1.1什么是计算机程序 1 1.2什么是计算机语言 1 1.3C语言的发展及其特点 3 1.4最简单的C语言程序 51.5运行C程序的步骤与方法1 2 1.6程序设计的任务14 1-5 #include <stdio.h>int main ( ){ printf ("**************************\n\n");printf(" Very Good!\n\n");printf ("**************************\n");return 0;}1-6#include <stdio.h>int main(){int a,b,c,max;printf("please input a,b,c:\n");scanf("%d,%d,%d",&a,&b,&c);max=a;if (max<b)max=b;if (max<c)max=c;printf("The largest number is %d\n",max); return 0;}第2章算法——程序的灵魂162.1什么是算法162.2简单的算法举例172.3算法的特性212.4怎样表示一个算法222.5结构化程序设计方法34习题36第章最简单的C程序设计——顺序程序设计37 3.1顺序程序设计举例373.2数据的表现形式及其运算393.3C语句573.4数据的输入输出65习题823-1 #include <stdio.h>#include <math.h>int main(){float p,r,n;r=0.1;n=10;p=pow(1+r,n);printf("p=%f\n",p);return 0;}3-2-1#include <stdio.h>#include <math.h>int main(){float r5,r3,r2,r1,r0,p,p1,p2,p3,p4,p5;p=1000;r5=0.0585;r3=0.054;r2=0.0468;r1=0.0414;r0=0.0072;p1=p*((1+r5)*5); // 一次存5年期p2=p*(1+2*r2)*(1+3*r3); // 先存2年期,到期后将本息再存3年期p3=p*(1+3*r3)*(1+2*r2); // 先存3年期,到期后将本息再存2年期p4=p*pow(1+r1,5); // 存1年期,到期后将本息存再存1年期,连续存5次p5=p*pow(1+r0/4,4*5); // 存活期存款。
《C语言程序设计习题与上机指南》答案第一部分习题篇第一章c语言概述一、单选题1.以下说法中正确的是(c)。
a) C语言程序总是从第一个函数开始执行b)在c语言程序中,要调用函数必须在main()函数中定义c)c语言程序总是从main()函数开始执行d) C语言中的main()函数必须放在程序的开头。
2.C语言程序由(b)组成。
a)一个主程序和若干子程序组成b)函数组成c)若干过程组成d)若干子程序组成3.C语言指定主函数在源程序中的位置(C)。
a)必须在开头b)必须在系统调用的库函数之后c)可以是任意的d)必须在结尾4。
以下陈述不正确(d)。
a)一个c源程序可由一个或多个函数组成b)一个c源程序必须包含一个main函数c)c程序的基本组成单位是函数d)在C程序中,注释只能放在一条语句之后。
5.以下关于C语言的陈述不正确(d)。
a)c语言既有高级语言的功能,也具有低级语言的一些功能b)c语言中的一条执行语句都必须用分号结束c)注释可以出现在程序中任意合适的地方d)include命令行后面必须加分号6.用c语言编写的代码程序(b)。
a)可以立即执行b)是一个源程序c)用高级语言(如c语言)编写的程序称为(a)源程序B)目标程序c)可执行程序d)编译器8。
函数的组成是(a)。
a)函数首部和函数体b)函数名和函数的声明部分c)主函数和子函数d)声明部分和执行部分9.在C语言中,用来表示“take address”的符号是(b)。
a)#b)和c)*d)10.c语言是计算机高级语言,它适合于作为系统描述语言,它(a)。
a)既可用来写系统软件,也可用来写应用软件b)只能写系统软件,不能用来写应用软件c)不能写系统软件,只能用来写应用软件d)既不能写系统软件,也不能写应用软件二.填空题1.C语言使用函数作为程序的模块单元,便于实现程序的模块化。
2.C语言允许直接访问物理地址和位操作。
3.用c语言编写的程序,每一个语句和数据定义的结尾必须要有一个分号。
习题答案 第1章 一、选择题 1. C 2. C 3. D 4. D 5. B 6. C 7. C 8. C 9. D 10. D 11. D 二、填空题 1. ;或分号 2. 字母、数字和下划线 3. .exe 第2章 一、选择题 1. A 2. C 3. D 4. A 5. B 6. A 7. D 8. D 9. C 10. B 11. C 12. D 13. A 14. B 二、填空题 1. 十六 2. 5 3. int型 4. double或双精度 5. 11 6. 3.5 7. 8 8. (x>20&&x<30)||(x<-100) 9. 字符型 10. 1个 11. int 第3章 一、选择题 1. A 2. A 3. A 4. A 5. A 6. D 7. D 8. B 9. B 10. C 11. A 12. B 二、填空题 1. double 2. 5.5 3. 26 三、程序分析题 1. 2 2. 6 第4章 一、选择题 1. A 2. A 3. C 4. B 5. A 6. C 7. B 8. D 9. C 10. C 11. B 12. C 13. A 二、填空题 1. 1 2. 0 3. 非0 4. (x%3==0) && (x%7==0) 5. || && ! 三、程序分析题 1. 把大写字母A-Z转换成对应的小写字母a-z,其它字符不转换。 2. 13 3. 4 四、程序填空题 1. (1)((a+b五、程序设计题 main() { int a,b,c,d,x; printf(“input a number:”); scanf(“%d”,&x); a=x/1000;x=x%1000; b=x/100; x=x%100; c=c/10;d=x%10; printf(“%d %d %d %d”,a,b,c,d); } 第5章 一、选择题 1. A 2. B 3. C 4. C 5. A 6. B 7. D 8. C 9. B 10. A 二、填空题 1. 3 2. 2 3. 5 三、程序分析题 1. -1 2. 5,4,6 四、程序填空题 1. 2*x+7*y==90 2. t=t*i t=-t/i 3. a%2!=1||a%3!=2||a%5!=4||a%6!=5 7 4. x>=0、x五、程序设计题 1. main(){ int m,n,k; float s=0; scanf(“%d%d”,&m,&n); for(k=m;k<=n;k++) s+=1.0/k; printf(“s=%f\n”,s);} 2. main() { float f1,f2,f3,s; int i; f1=f2=1; s=0; for(i=1;i<=20;i++) { f3=f2+f1;s+=f3/f2;f1=f2;f2=f3;} printf(“%f”,s); } 3. main() { int a,b,c,k; for(k=100;k<1000;k++) { a=k/100; b=(k-100*a)/10; c=k%10; if (k==(a+b+c)*a*b*c) printf("%d,",k); } } 第6章 一、选择题 1. D 2. D 3. C 4. D 5. D 6. D 7. A 8. A 9. C 10. D 11. C 12. C 13. A 14. D 15. B 16. A 17. B 18. C 19. C 20. C 二、填空题 1. char xm[61][10]; 2. 123569 3. ‘\0’ 4. 101418 三、程序分析题 1. m=82,j=7 2. abc 四、程序填空题 1. s[i]>='0' && s[i]<='9' 2. ‘\0’ str1[i]-str2[i] 五、程序设计题 1. main() { int i,j,a[3][3].sum=0; for(i=0;i<3;i++) for(j=0;j<3;j++) scanf(“%d”,&a[i][j]); for(i=0;i<3;i++) sum+=a[i][i]; printf(“%d”,sum); } 2. main() { int i,j,max; int a[3][4]={{1,3,5,7},{2,4,6,8},{15,17,34,12}}; max=a[0][0]; for(i=0;i<3;i++) for(j=0;j<4;j++) if(a[i][j]>max) max=a[i][j]; printf(“max is %d”,max); } 3. #include “stdio.h” main() { int term[10]; int i,max,min; printf(“请输入10个整数:”); for(i=0;i<10;i++) scanf(“%d”,&term[i]); max=term[0]; min=term[0]; for(i=0;i<10;i++) { if(term[i]if(term[i]>max)max=term[i];} printf(“max=%d,min=%d”,max,min);} 第7章 一、选择题 1. D 2. A 3. A 4. C 5. A 6. A 7. A 8. B 9. B 10. B 11. C 12 A 13. D 14. C 15. D 二、填空题 1. 函数说明部分 2. { } 3. main()函数 4. 主函数 函数 5. return 三、程序分析题 1. 0 1 2 3 2. 15 3. 5,6 四、程序填空题 1. a[0]+sum(a+1,n-1)或sum(a,n-1)+a[n-1]或sum(a,n/2)+a[n/2]+sum(a+n/2+1,n-n/2-1 return 0 2. 1、s*i、0、f(k) 3. str str[i]=str[j-1] str[j-1]=t 五、程序设计题 1. long power(int x, int n) { long p=1; for ( int i=1;i<=n;i++) p*= x; return (p); } 2. long fun (int n) { long p=1; for ( int i=1;i<=n;i++) p*= i; return (p); } 3. int fib(int n) { if(n==0)return(0); if(n==1) return(1); if(n>1) return(fib(n-2)+fib(n-1)); } 第8章 一、选择题 1. B 2. A 3. C 二、填空题 1. 8 第9章 一、选择题 1. B 2. B 3. D 4. C 5. C 6. B 7. A 8. D 二、填空题 1. 共用体 2. 22 3. 结构体 4. typedef enum color {red,blue,white,green,yellow} COLOR; 5. 34 三、程序分析题 1. 1984,12 2. 2 第10章 一、选择题 1. D 2. C 3. C 4. C 5. B 6. D 7. A 8. D 9. C 10. A 11. C 12. D 13. C 14. C 15. B 16. C 17. D 18. C 19. A 20. A 21. C 二、填空题 1. 2 2. 60 3. 135 11. eybdooG 三、程序分析题 1. 60 2. porm 3. 9 四、程序填空题 1. ① int *x, int *y ② *y=temp ③ &x,&y 五、程序设计题 1. void chg(char *s) { int i,j,k; k=strlen(s); for(i=0;i{ if(s[i]=='z'||s[i]=='Z' ) s[i]=s[i]-25; else if(isalpha(s[i])) s[i]+=1; } } 2. #define M 61 main() { char p[M],*q; int I,upper=0,lower=0; for(I=0;I<3;I++) gets(p[I]); for(I=0;I<3;I++) { q=p[I]; while(*q) {if(*q>=’A’&&*q<=’Z’){upper++;q++;} if(*q>=’a’&&*q<=’z’){lower++;q++;} } } printf(“%d,%d”,upper,lower); } 第11章 一、选择题 1. C 2. B 3. A 4. C 5. A 6. A 7. A 8. B 9. D 10. C 11. B 12. C 13. C 14. C 二、填空题 1. 非零值 2. 存储在外部介质上的相关数据集合。 3. FILE 三、程序填空题 1. fp==0 、 !feof(fp) 第12章 一、选择题 1. D 2. A 3. B 二、程序分析题 1.第一个错误:程序中语句"value=FU(a+b,a-b)+FU(c+b,c-b);"应改为