C++程序设计教程 课后答案第三章 李秉璋
c程序设计第三版课后习题答案
c程序设计第三版课后习题答案C程序设计第三版课后习题答案C程序设计是计算机科学中一门重要的编程语言,它的应用广泛,被广泛应用于软件开发、嵌入式系统、操作系统等领域。
而C程序设计第三版是一本经典的教材,为学习C语言的初学者提供了全面而系统的知识讲解。
在学习过程中,课后习题是巩固知识的重要环节,下面将为大家提供一些C程序设计第三版课后习题的答案。
1. 习题一:编写一个C程序,计算并输出1到100之间所有奇数的和。
```c#include <stdio.h>int main() {int sum = 0;for (int i = 1; i <= 100; i += 2) {sum += i;}printf("1到100之间所有奇数的和为:%d\n", sum);return 0;}```2. 习题二:编写一个C程序,判断一个输入的整数是否是素数。
```c#include <stdio.h>int isPrime(int num) {if (num <= 1) {return 0;}for (int i = 2; i * i <= num; i++) { if (num % i == 0) {return 0;}}return 1;}int main() {int num;printf("请输入一个整数:");scanf("%d", &num);if (isPrime(num)) {printf("%d是素数。
\n", num); } else {printf("%d不是素数。
\n", num); }return 0;}3. 习题三:编写一个C程序,将一个十进制数转换为二进制数。
```c#include <stdio.h>void decimalToBinary(int num) {if (num == 0) {return;}decimalToBinary(num / 2);printf("%d", num % 2);}int main() {int num;printf("请输入一个十进制数:");scanf("%d", &num);printf("转换为二进制数为:");decimalToBinary(num);printf("\n");return 0;}```4. 习题四:编写一个C程序,实现两个整数的交换。
C++课后题答案
C语言程序设计(第3版)-参考答案
C语言程序设计(第3版)-参考答案C语言程序设计(第3版) - 参考答案C语言是一种广泛应用于软件开发领域的编程语言,它具有高效、简洁、灵活等特点。
《C语言程序设计(第3版)》是一本经典的教材,本文将提供一些参考答案,帮助读者更好地理解和掌握C语言程序设计。
一、基础知识1. 什么是C语言?C语言是一种通用的编程语言,由贝尔实验室的Dennis Ritchie开发,在20世纪70年代广泛流行起来。
它被设计为一种低级语言,可以直接操作计算机硬件,并提供了足够的抽象层次来方便高级程序设计。
2. 如何输出“Hello, World!”?在C语言中,使用printf函数可以输出文本信息。
要输出“Hello, World!”,可以使用以下代码:```#include <stdio.h>int main() {printf("Hello, World!\n");return 0;}```3. 如何定义和使用变量?在C语言中,可以使用关键字`int`、`float`、`char`等定义变量。
例如:```int age = 20;float weight = 60.5;char grade = 'A';```定义后的变量可以用于存储不同类型的值,并在程序中进行操作和输出。
二、控制流程1. 什么是条件语句?条件语句允许程序通过判断条件来选择性地执行不同的代码块。
在C语言中,常用的条件语句是`if`语句。
例如:```if (score >= 60) {printf("Pass\n");} else {printf("Fail\n");}```根据变量`score`的值,判断学生是否及格并输出相应结果。
2. 什么是循环语句?循环语句可以重复执行一段代码块,以达到多次执行的目的。
在C 语言中,常用的循环语句有`for`、`while`和`do while`。
《C语言程序设计教程》第三版课后习题参考答案
《C语言程序设计教程》第三版课后习题参考答案C语言程序设计教程第三版课后习题参考答案第一章:C语言概述1.1 C语言的特点答案:C语言是一种通用的、面向过程的程序设计语言,具有高效、简洁、灵活等特点。
它提供了丰富的程序设计元素和功能,适用于各种不同的应用领域。
1.2 C语言程序的基本结构答案:C语言程序由预处理指令、函数声明、函数定义、变量声明和语句组成。
其中,预处理指令用来引入头文件或定义宏,函数声明用来声明函数的名称和参数,函数定义用来实现函数的功能,变量声明用来声明变量的类型和名称,语句用来表达具体的计算过程。
1.3 C语言的数据类型答案:C语言提供了多种数据类型,包括基本类型(整型、浮点型、字符型等)和派生类型(数组、指针、结构体等)。
每种数据类型在内存中占据一定的存储空间,并具有特定的取值范围和操作规则。
1.4 C语言的运算符和表达式答案:C语言支持各种运算符和表达式,例如算术运算符(+、-、*、/等)、关系运算符(>、<、==等)、逻辑运算符(&&、||、!等)等。
通过运算符和表达式可以进行各种数值计算和逻辑判断。
第二章:基本数据类型与运算2.1 整型数据类型答案:C语言提供了不同长度的整型数据类型,包括有符号整型(int、long等)和无符号整型(unsigned int、unsigned long等)。
整型数据类型可以表示整数值,并具有不同的取值范围。
2.2 浮点型数据类型答案:C语言提供了浮点型数据类型(float、double等),用来表示带小数部分的实数值。
浮点型数据可以表示较大或较小的数值,并具有一定的精度。
2.3 字符型数据类型答案:C语言提供了字符型数据类型(char),用来表示单个字符。
字符型数据可以用于表示各种字符(包括字母、数字、符号等)。
2.4 布尔型数据类型答案:C语言不直接支持布尔型数据类型,但可以使用整型数据类型来表示布尔值(0表示假、非零表示真)。
C++程序设计基础课后答案第三章
C++程序设计基础课后答案第三章3.1 阅读下列程序,写出执行结果1. #include#includeint f( int ) ;void main(){ int i;for( i = 0; i < 3; i ++ )cout << f( i ) << endl;}int f( int a ){ int b = 0 , c = 1;b ++; c++;return ( a + pow( b, 2 ) + c );}2. void func(int a, int b, int c = 3, int d = 4 ); #includevoid main(){ func( 10, 15, 20, 30 );func( 10, 11, 12 );func( 12, 12 );}void func( int a, int b, int c, int d ){ cout << a << '\t' << b << '\t' << c << '\t' << d << endl; }3.#includevoid func( int, int, int * ) ;void main(){ int x, y, z;func( 5, 6, &x );func( 7, x, &y );func( x, y, &z );cout << x << " ," << y << ", "<< z << endl;}void func( int a , int b , int *c ){ b += a ; *c = b – a ; }4.#includevoid func( int, int, int & );void main(){ int x=0 , y=1 , z=2;func( 1 , 2 , x );func( x + y , y , y );func( z , x + y , z );cout << x << " ," << y << ", "<< z << endl ;}void func( int a , int b , int &c ) { b += a ; c = b – a ; }5. #includeint f2( int, int );int f1( int a , int b ){ int c ;a += a ;b += b ;c = f2( a+b , b+1 );return c;}int f2( int a , int b ){ int c ;c = b % 2 ;return a + c;}void main(){ int a = 3 , b = 4;cout << f1( a , b ) << endl;}6. #includeint age( int n ){ int f;if( n == 1 ) f = 10 ;else f = age( n-1 ) + 2;return f ;}void main(){ cout << "age : " << age( 5 ) << endl; }7. #includeint f1( int a , int b ) { return a + b ; }int f2( int a , int b ) { return a - b ; }int f3( int( *t )( int , int ) , int a , int b ) { return ( *t )( a, b ) ; } void main(){ int ( *p )( int, int );p = f1 ;cout << f3( p, 4, 8 ) << endl;p = f2 ;cout << f3( p, 8, 4 ) << endl;}8.#includeint sub( int, int );int a = 1 ;void main(){ int m = 1, n = 2, f;f = sub( m, n );cout << a << '\t' << f << endl;f = sub( m, n ) ;cout << a << '\t' << f << endl;}int sub( int c, int d ){ static int m = 2, n = 5 ;cout << m << '\t' << n << '\t' << endl;a = ++ a ; c = m ++ ; d = n ++;return c + d ;}3.2 思考题1.函数的作用是什么?如何定义函数?什么叫函数原型?2.什么叫函数值的返回类型?什么叫函数的类型?如何通过指向函数的指针调用一个已经定义的函数?请写一个验证程序说明。
c语言程序设计第三章答案
第三章习题答案一、选择题(带**号的题选作)1) 以下叙述中正确的是()A) C语言的基本组成单位是语句B) C程序中的每一行只能写一条语句C) 简单C语句必须以分号结束D)C语句必须在一行内完成2)下列叙述中错误的是A)计算机不能直接执行用C语言编写的源程序B)C程序经C编译程序编译后,生成后缀为.obj的文件是一个二进制文件C) 后缀为.obj的文件,经连接程序生成后缀为.exe的文件是一个二进制文件 D)后缀为.obj和.exe的二进制文件都可以直接运行3) 计算机能直接执行的程序是()A)源程序 B)目标程序 C)汇编程序 D)可执行程序4)以下叙述中错误的是A)C语言是一种结构化程序设计语言B)结构化程序有顺序、分支、循环三种基本结构组成C)使用三种基本结构构成的程序只能解决简单问题D)结构化程序设计提倡模块化的设计方法5)对于一个正常运行的C程序,以下叙述中正确的是A)程序的执行总是从main函数开始,在main函数结束B)程序的执行总是从程序的第一个函数开始,在main函数结束C)程序的执行总是从main函数开始,在程序的最后一个函数中结束D)程序的执行总是从程序的第一个函数开始,在程序的最后一个函数中结束6)以下叙述中正确的是A)C语言程序将从源程序中第一个函数开始执行B)可以在程序中由用户指定任意一个函数作为主函数,程序将从此开始执行C)C语言规定必须用main作为主函数名,程序将从此开始执行,在此结束D)main可作为用户标识符,用以命名任意一个函数作为主函数7) 以下关于C语言的叙述中正确的是A) C语言中的注释不可以夹在变量名或关键字的中间B) C语言中的变量可以再使用之前的任何位置进行定义C) 在C语言算术的书写中,运算符两侧的运算数类型必须一致D) C语言的数值常量中夹带空格不影响常量值的正确表示8)以下叙述中错误的是A)C程序在运行过程中所有计算都以二进制方式进行B)C程序在运行过程中所有计算都以十进制方式进行C)所有C程序都需要编译链接无误后才能运行D)C程序中整型变量只能存放整数,实型变量只能存放浮点数9)以下叙述中正确的是A) C程序中的注释只能出现在程序的开始位置和语句的后面B) C程序书写格式严格,要求一行内只能写一个语句C) C程序书写格式自由,一个语句可以写在多行上D) 用C语言编写的程序只能放在一个程序文件中10)C语言源程序名的后缀是A).exe B).C C).obj D).cp11)以下叙述中错误的是A)在程序中凡是以“#”开始的语句行都是预处理命令行B)预处理命令行的最后不能以分号表示结束C)#define MAX是合法的宏定义命令行D)C程序对预处理命令行的处理是在程序执行的过程中进行的12) 以下选项中不能作为C语言合法常量的是 ( )A) ‘cd’ B) 0.1e+6 C) “a” D)‘\011’13)一下选项中,能用作数据常量的是A)o115 B)0118 C)1.5e1.5 D)115L14) 以下选项中不属于字符常量的是A)'C' B)"C" C)'\xCC0' D)'\072' 15)以下合法的字符型常量是A)’\x13’B)’\018’C)”65” D)”\n”16) 以下不合法的字符常量是A)'\018' B)'\”' C) '\\' D) ‘\xcc' 17) 以下不合法的数值常量是A)011 B)1e1 C) 8.0E0.5 D) 0xabcd 18)以下选项中能表示合法常量的是A)整数:1,200 B)实数:1.5E2.0C)字符斜杠:‘\’ D)字符串:"\007"19) C源程序中不能表示的数制是()A) 二进制 B) 八进制 C) 十进制 D) 十六进制20) 以下选项中,合法的一组C语言数值常量是A)028 B)12. C).177 D)0x8A.5e-3 OXa23 4c1.5 10,000-0xf 4.5e0 Oabc 3.e521)以下不合法的用户标识符是A)j2_KEY B)Double C) 4d D) _8_22)一下选项中合法的标识符是A)1_1 B)1-1 C)_11 D)1_ _23) 以下选项中,能用作用户标识符的是A)void B)8_8 C)_0_ D)unsigned 24)按照C语言规定的用户标识符命名规则,不能出现在标识符中的是A)大写字母 B)连接符 C)数字字符 D)下划线25)可在C程序中用做用户标识符的一组标识符是A)and B)Date C)Hi D)case _2007 y-m-d Dr.Tom Bigl26) 以下C语言用户标示符中,不合法的是A)_1 B)AaBc C)a_b D)a--b 27)以下选项中不合法的标识符是A)print B)FOR C)&a D)_00 28)下列定义变量的语句错误的是()。
c程序设计第三习题解答全
C程序设计(第三版)课后习题参考解答第1章C语言概述1.5 参照本章例题,编写一个C程序,输出以下信息:******************************Very Good!******************************解:main ( ){printf(“****************************** \n”);printf(“\n”);printf(“Very Good! \n”);printf(“\n”);printf(“****************************** \n”);}1.6 写一个程序,输入a,b,c三个值,输出其中最大者。
解:main ( ){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);}第2章程序的灵魂——算法2.1 什么叫结构化的算法?为什么要提倡结构化的算法?解:由一些基本结构顺序组成的算法称为结构化的算法。
由于在基本结构之间不存在非顺序的跳转,流程的转移只存在于一个基本结构范围之内,因而提高了算法的质量。
2.7 什么叫结构化程序设计?它的主要内容是什么?解:结构化程序就是用高级语言表示的结构化算法。
它的主要内容包括“自顶向下,逐步细化”的分析方法和“模块化设计”的解决方法,以及“结构化编码”的实现方法。
第3章数据类型、运算符与表达式3.4将以下三各整数分别赋给不同类型的变量,请画出赋值后数据在内存中的存储形式。
注:如果没有学过二进制和补码,此题可以不做。
解:各数据在内存中的存储形式如下表所示:它是一个负数的补码,对其再求一次补码可得其真值,即-(65536-32769)=-32767。
《C语言程序设计教程》(第三版)课后习题参考答案(精选5篇)[修改版]
第一篇:《C语言程序设计教程》(第三版)课后习题参考答案C语言程序设计课后习题参考答案习题一一、单项选择题1、C2、B3、B4、C5、D6、A7、C8、A二、填空题1、判断条件2、面向过程编程3、结构化4、程序5、面向对象方法6、基本功能操作、控制结构7、有穷性8、直到型循环结构9、算法10、可读性11、模块化12、对问题的分解和模块的划分习题二一、单项选择题1、B2、D3、C4、B5、A二、填空题1、主2、C编译系统3、结构化4、程序5、面向对象方法6、.OBJ7、库函数8、直到型循环结构习题三一、单项选择题1、D2、B3、A4、C9、B10、C11、A12、D13、C17、B18、C19、C20、D21、A25、D26、A二、填空题1、补码2、10^-138~10^1 38、15~166、A7、B6、D7、B14、B15、C22、D8、C8、D16、A24、D、A3、实4、单目运算符、自右向左5、函数调用6、65,89习题四一、单项选择题1、D2、C3、D4、A5、D6、B7、A8、C9、B10、B二、填空题1、两, ;2、5.1690003、-200 2500、i=-200,j=2500回车、i=-200回车j=2500回车4、a=98,b=765.000000,c=4321.0000005、100 25.81 1.89234、100,25.81,1.89234、100回车25.81回车1.89234回车6、0,0,37、38、scanf(“%lf %lf %lf”,&a,&b,&c);9、13 13.000000 13.00000010、c=b-a;a=b+c;习题五一、单项选择题1、B2、D3、C4、B5、B6、D7、A8、B二、填空题1、1 、02、k!=03、if(x>4||xelse printf(“error!”); 4、if(((x>=1&&x=200&&x Printf(“%d”,x);5、16、17、10! Right!8、a=09、2,110、0习题六一、单项选择题9、D1、B2、C3、C4、B5、C6、B7、C8、A二、填空题1、无穷次2、83、205、3.66、*#*#*#$7、828、d=1.0 、k++、k9、!(x习题七一、单项选择题1、B2、D3、C4、C5、A二、填空题1、1 2 4 8 16 32 64 128 256 5122、a[age]++、i=18;i3、break、i==84、a[i]>b[i]、i3、j5、b[j]=0、b[j]=a[j][k]习题八一、单项选择题1、B3、C4、A5、A9、D10、B11、A12、C13、A二、填空题1、return1、return n+sum(n-1)2、return1、n*facto(n-1)习题九一、单项选择题1、D2、C3、D4、A5、C9、B10、C11、A13、B17、C18、A19、B20、C二、填空题1、int 、return z2、*p++3、’\0’、++4、p、max*q6、A7、D6、A7、C14、C15、B6、C7、C14、A15、D8、A8、D8、C习题十一、单项选择题1、D2、D3、A4、5、B6、A7、C8、B9、D10、11、C12、D13、D14、C二、填空题1、34 122、ARRAY a[10],b[10],c[10];3、2 34、ab、cd5、(*b).day、b->day6、adghi mnohi no7、(struct node *)、!=’\n’、p=top;8、p1=p1->next9、(struct list *)、(struct list *)、return (n)习题十一一、单项选择题1、A2、A3、B4、A5、B9、A10、B11、B12、B13、C17、D二、填空题1、ASCII(文本)、二进制2、pf=fopen(“A:\zk04\data xfile.dat”,”w”);3、fputc()、fputs()、fscanf()、fread()4、(后两个空)文件结束符、非0值7、B14、C15、D8、A16、A第二篇:C语言程序设计教程课后习题参考答案《C语言程序设计教程》课后习题参考答案习题1 1. (1)编译、链接.exe (2)函数主函数(或main函数)(3)编辑编译链接2.(1)-(5):DDBBC (6)-(10):ABBBC 3.(1)答:C语言简洁、紧凑,使用方便、灵活;C语言是高级语言,同时具备了低级语言的特征;C 语言是结构化程序设计语言,具有结构化的程序控制语句;C语言有各种各样的数据类型;C语言可移植性好;生成目标代码质量高,程序执行效率高。
c语言第四版答案第三章,《C语言程序设计》课后习题答案(第三章)
c语⾔第四版答案第三章,《C语⾔程序设计》课后习题答案(第三章)3.3 请写出下⾯程序的输出结果.结果:575 767.856400,-789.12396267.856400,-789.12396267.86,-789.12,67.856400,-789.123962,67.856400,-789.1239626.785640e+001,-7.89e+002A,65,101,411234567,4553207,d68765535,17777,ffff,-1COMPUTER, COM3.4 ⽤下⾯的scanf函数输⼊数据,使a=3,b=7,x=8.5,y=71.82,c1='A',c2='a',问在键盘上如何输⼊?main(){inta,b;floatx,y;charc1,c2;scanf("a=%d b=%d,&a,&b);scanf("x=%f y=%e",&x,&y);scanf("c1=%c c2=%c",&c1,&c2);}解:可按如下⽅式在键盘上输⼊:a=3 b=7x=8.5 y=71.82c1=A c2=a(说明:在边疆使⽤⼀个或多个scnaf函数时,第⼀个输⼊⾏末尾输⼊的"回车"被第⼆个scanf函数吸收,因此在第⼆\三个scanf函数的双引号后设⼀个空格以抵消上⾏⼊的"回车".如果没有这个空格,按上⾯输⼊数据会出错,读者⽬前对此只留有⼀初步概念即可,以后再进⼀步深⼊理解.)3.5 ⽤下⾯的scanf函数输⼊数据使a=10,b=20,c1='A',c2='a',x=1.5,y=-3.75,z=57.8,请问在键盘上如何输⼊数据?scanf("%5d%5d%c%c%f%f%*f%f",&a,&b,&c1,&c2,&y,&z);解:main(){inta,b;floatx,y,z;charc1,c2;scanf("%5d%5d%c%c%f%f",&a,&b,&c1,&c2,&x,&y,&z);}运⾏时输⼊:10 20Aa1.5 -3.75+1.5,67.8(注解:按%5d格式的要求输⼊a与b时,要先键⼊三个空格,⽽后再打⼊10与20。
C程序设计(第三版)习题答案(1-6章) 谭浩强著(1)_官田
printf("l=%6.2f\n",l);
printf("s=%6.2f\n",s);
printf("sq=%6.2f\n",sq);
printf("vq=%6.2f\n",sv);
printf("vz=%6.2f\n",sz);
void main()
{
int max(int x,int y,int z);
int a,b,c,d;
scanf("%d,%d,%d",&a,&b,&c);
d=max(a,b,c);
printf("max=%d\n",d);
printf("a=%2d b=%2d c=%2d\n",a,b,c);
printf("x=%8.6f,y=%8.6f,z=%9.6f\n",x,y,z);
printf("x+y=%5.2f y+z=%5.2f z+x=%5.2f\n",x+y,y+z,z+x);
}
5.6
main()
{int score,temp,logic;
char grade;
logic=1;
while(logic)
{scanf("%d",&score);
if(score>=0&&score<=100)logic=0;
A,65,101,41
1234567,4553207,d687
C程序设计(第四版)_谭浩强_第三章_课后习题答案-推荐下载
对全部高中资料试卷电气设备,在安装过程中以及安装结束后进行高中资料试卷调整试验;通电检查所有设备高中资料电试力卷保相护互装作置用调与试相技互术通关,1系电过,力管根保线据护敷生高设产中技工资术艺料0不高试仅中卷可资配以料置解试技决卷术吊要是顶求指层,机配对组置电在不气进规设行范备继高进电中行保资空护料载高试与中卷带资问负料题荷试2下卷2,高总而中体且资配可料置保试时障卷,各调需类控要管试在路验最习;大题对限到设度位备内。进来在行确管调保路整机敷使组设其高过在中程正资1常料中工试,况卷要下安加与全强过,看度并22工且22作尽22下可22都能22可地护以缩1关正小于常故管工障路作高高;中中对资资于料料继试试电卷卷保破连护坏接进范管行围口整,处核或理对者高定对中值某资,些料审异试核常卷与高弯校中扁对资度图料固纸试定,卷盒编工位写况置复进.杂行保设自护备动层与处防装理腐置,跨高尤接中其地资要线料避弯试免曲卷错半调误径试高标方中高案资等,料,编试要5写、卷求重电保技要气护术设设装交备备置底4高调、动。中试电作管资高气,线料中课并敷3试资件且、设卷料中拒管技试试调绝路术验卷试动敷中方技作设包案术,技含以来术线及避槽系免、统不管启必架动要等方高多案中项;资方对料式整试,套卷为启突解动然决过停高程机中中。语高因文中此电资,气料电课试力件卷高中电中管气资壁设料薄备试、进卷接行保口调护不试装严工置等作调问并试题且技,进术合行,理过要利关求用运电管行力线高保敷中护设资装技料置术试做。卷到线技准缆术确敷指灵设导活原。。则对对:于于在调差分试动线过保盒程护处中装,高置当中高不资中同料资电试料压卷试回技卷路术调交问试叉题技时,术,作是应为指采调发用试电金人机属员一隔,变板需压进要器行在组隔事在开前发处掌生理握内;图部同纸故一资障线料时槽、,内设需,备要强制进电造行回厂外路家部须出电同具源时高高切中中断资资习料料题试试电卷卷源试切,验除线报从缆告而敷与采设相用完关高毕技中,术资要资料进料试行,卷检并主查且要和了保检解护测现装处场置理设。备高中资料试卷布置情况与有关高中资料试卷电气系统接线等情况,然后根据规范与规程规定,制定设备调试高中资料试卷方案。
c程序设计第三版习题参考解答(全)
printf( “c1=?%c?or %d(ASCII)\n ”,c1,c1); printf( “c2=?%c?or %d(ASCII)\n ”,c2,c2);
4
}
4. 5 请写出下面程序的输出结果:
main ( )
{ int a=5,b=7;
float x=67.8564,y=-789.124;
char c=?A?;
long n=1234567; unsigned u=65535;
printf( “%d%d\n ”,a,b); printf( “%3d%3d\n ”,a,b); printf( “%f,%f\n ”,x,y); printf( “%-10f,%-10f\n ”,x,y); printf( “%8.2f, %8.2f,%4f, %4f, %3f, %3f\n printf( “%e,%10.2e\n”,x,y); printf( “%c,%d,%o,%x\n ”,c,c,c,c);
第 1 章 C 语言概述
C 程序设计(第三版)课后习题参考解答
1.5 参照本章例题,编写一个 ****************************** Very Good! ****************************** 解:
C 程序,输出以下信息:
main ( )
{printf( “****************************** \n
max=b; if (max<c) max=c; printf( “最大数为: %d ”,max); }
第 2 章 程序的灵魂——算法
2.1 什么叫结构化的算法?为什么要提倡结构化的算法? 解:由一些基本结构顺序组成的算法称为结构化的算法。
C51程序设计课后答案3.doc
第三章习题答案一、选择题二、填空题1、 分号2、 输入一个字符数据、输出一个字符数据3、 任何、地址4、 %6D,%06.2F5、 ab%iro6、 t=a7> aabbt-j LJ LJ LJCC8、A9> Glmre10、 a 与b 互换11、 int num,totaltotal,num12、 a 二 10,跳过 20, b=30,c=4013、 #include<stdio.h>putchar(b) putchar(c)14、 scanf(“%d%f%c 冷&a ,&x ,&c);12.6A15、 a=98,b 二765.000000,c=4321.000000三、简答题1、 C 语句可以分为以下5类:表达式语句空语句复合语句函数调用语句流程控制语句2、 表达式与表达式语句的区别:表达式语句就是在一个表达式的后面加一个分号 “;”构成。
表达式语句常作为赋值语句使用。
3、 C 语言有四种输入输出函数:getchar()> putchar()、scanf()和 printf()函数。
getchar()函数可输入一个字符;putchar()函数用于输出一个字符;scanf()函数可输入任何类型的数据; printf()函数用于输出任何类型的数据。
4、 s canf 格式字符及附加格式说明符及使用方法:(1) <1格式符,用来输入十进制整数。
1. B5、D9、A13、B 2、B 6、B 3、C 7、D 4、D 8、A10、B 14、D 11、C 15、C(2)o格式符,用来输入八进制整数。
(3)x格式符,用来输入十六进制整数。
(4)c格式符,用来输入单个字符。
(5)s格式符,用来输入字符串,并将字符串送到1个字符数组屮。
(6)f格式符,用來输入实数,可以用小数形式或指数形式输入。
(7)e格式符和g格式符,与f格式符作用相同,e、f和g可以互相替换。
c程序设计教程习题参考答案
《C语言程序设计教程》习题参考答案祝胜林主编华南理工大学出版社【习题1】 (1)【习题2】 (2)【习题3】 (3)【习题4】 (5)【习题5】 (8)【习题6】 (11)【习题7】 (14)【习题8】 (17)【习题9】 (17)【习题10】 (20)一、简答题(在课本中寻找答案,略)C程序的基本结构包括哪些内容?如何定义标识符?输入格式、输出格式的组成包括哪些内容?C语言函数分为哪两类?计算表达式的值应该考虑哪些方面?上机调试程序的步骤如何?二、判断并改错C程序执行的入口是main()函数,所以main函数必须放在程序的开头。
错误:main函数可以放在程序的任何位置。
并不限定在程序的开头。
定义一个函数包括数据说明部分和执行语句部分,两者可以交叉出现。
错误:不可以交叉出现,数据说明部分在执行语句部分的前面。
编辑与编译不是一回事。
错误:不是一回事。
编辑完成源程序的输入和修改;编译是对源程序进行语法检查,如果无语法错误,则生成目标程序。
scanf("%d,%d",&x,&y);的正确输入格式:3,4<回车>。
正确注释内容太多会影响程序的执行效率。
错误:不会影响程序的执行效率。
因为在编译时,编译系统将注释内容删除或用空格代替,所以注释内容不会编译到目标程序中。
所有的数学公式可以直接出现在源程序中。
错误:数学公式需要转换成C语言能够接受的公式才能出现在源程序中。
三、编程题在屏幕上输出自己名字的拼音。
提示:中文名字叫“张三”,对应的拼音为“Zhang San”,输出用printf()函数。
4 输入圆的半径,求圆的周长,并将结果保留两位小数输出到屏幕上。
提示:定义圆的半径r,圆的周长:2*3.14*r,输出结果保留2位小数可以用%.2f输入两个整数,输出其中最大者。
1.16 输入三个整数,输出其中最小者。
提示: min(min(a,b),c);一、简答题(在课本中寻找答案,略)常量与变量的区别?2.2 C语言中的标识符的定义规则?变量为什么要“先定义,后使用”?字符常量'a'与字符串常量"a"有何区别?大小写字母转换的规则是什么?变量的具有哪三种属性?二、单项选择题2.7 C语言中,int型数据在内存中的存储形式是(D)。
c语言详解(第五版)第三章程序设计项目答案.docx
C语言详解(第五版〉第三章程序设计项目答案1•假设买一辆车首付为SOOdollar。
请计算月供。
#include<stdio. h>#include〈math・ h> #include<stdlib. h>int main(void){double capital_sum, monthly_intcrcst_ratc, initial_payment, temp, payment, terms; prinIf("Please enter the price of the car>>");scanf (,z%lf",&capital_sum);printf ("Please enter the monthly interest rate»z,);scanf(〃%]f", &monthly interest rate);printf ("Please enter the terms duration of loan>>,z);sea,&terms);printf ("Please enter the initial_payment»/z);seanf ("%1 f", & ini tial—payment);temp=l+monthly interest rate; paymcnt=(capital_sum-500)*monthly_intcrcst_ratc/(l-pow(tcmp, -terms)); prinIf ("The monthly contribution is %・2f dollars •“, payment);printf ("The capital sum is %・2f dollarscapital_sum);system("pause");return 0;}2•编写两个函数,一个显示三角形,另一个显示矩形。
C程序设计(第四版)_谭浩强_第三章_课后习题答案
最简单的C程序设计——顺序程序设计P037 3.1 把华氏温度转化为摄氏表示法.#include<stdio.h>float F_to_C(float input_fah) //代表华转摄,input_fah是局部变量.{float output_cen; //这里也是局部变量.output_cen=(5.0/9)*(input_fah-32); //函数的功能体.return output_cen; //返回值,注意,返回值的数据类型应该和函数一致.}float C_to_F(float input_cen){float output_fah;output_fah=(9.0/5)*input_cen+32; //转换过程.return output_fah;}int main(){int choice;float input_fah,input_cen,output_fah,output_cen; //局部变量的调用及参数传递.printf("F_to_C press <1> and C_to_F press <2> !\n");scanf("%d",&choice);if(choice==1){printf("Please input fahrenheit :");scanf("%f",&input_fah); //这个是主函数定义的变量,虽然和调用函数同名.output_cen=F_to_C(input_fah);printf("The 华氏 is %d , 摄氏 is %d .",(int)input_fah,(int)output_cen);}if(choice==2){printf("Please input centigrade :");scanf("%f",&input_cen);output_fah=C_to_F(input_cen);printf("The Centigrade is %d , and the Fahrenheitis %d .",(int)input_cen,(int)output_fah);}return 0;}P038 3.2 计算存款利息(关于精度问题).#include<stdio.h>int main(){float p0=1000,r1=0.0036,r2=0.0225,r3=0.0198,p1,p2,p3;p1=p0*(1+r1);p2=p0*(1+r2);p3=p0*(1+r3/2)*(1+r3/2);printf("p1=%f\np2=%f\np3=%f\n",p1,p2,p3);return 0;}#include<stdio.h>int main() //小写范围是97-122,大写范围是65-90,大写加上即得小写.26个字母. {char c1, c2;c1='A';c2=c1+32;printf("%c %d",c2,c2);return 0;}P059 3.4 给出三角形边长,算出面积.#include<stdio.h>#include<math.h>int main(){double a=3.67, b=5.43, c=6.21, s, area;s=(a+b+c)/2;area=sqrt(s*(s-a)*(s-b)*(s-c));printf("area is %f\n",area); //默认可以组成三角形.return 0;P065 3.5 求一无二次等式的根,默认两个不同根.#include<stdio.h>#include<math.h>int main(){double a,b,c,disc,x1,x2,p,q;scanf("%lf %lf %lf",&a,&b,&c);disc=b*b-4*a*c;p=-b/(2.0*a);q=sqrt(disc)/(2.0*a);x1=p+q;x2=p-q;printf("x1=%7.2f\nx2=%7.2f",x1,x2);return 0;}#include<stdio.h>#include<math.h>int main(){double a=1.0; //1是整型,1.0是浮点型,默认是double.可以是float.printf("%.9f\n",a/3);return 0;}#include<stdio.h>#include<math.h>int main(){float a; //输出的结果是.333252,float精度6位,所以第七位后不可信.a=10000/3.0;printf("%f\n",a);return 0;}#include<stdio.h>#include<math.h>int main(){char a='B',b='O',c='Y';putchar(a);putchar(b);putchar(c);putchar('\n');putchar(101); //101是A的ASCII代码的缩写,因为此函数只能输出字符.putchar(66);return 0;}P079 3.9 使用getchar得到字符.#include<stdio.h>#include<math.h>int main(){char a,b,c;a=getchar();b=getchar();c=getchar();putchar(a);putchar(b);putchar(c); //这也是基本回显的C程序代码.putchar('\n');return 0;}#include<stdio.h>#include<math.h>int main(){char a,b;a=getchar();b=a+32;putchar(b);putchar('\n');return 0;}#include<stdio.h>#include<math.h>int main(){double p,r=0.09,n=10;p=pow((1+r),n); //这是数学函数, pow(x,y)计算x的y次方.printf("P is %lf when 10 years later .\n",p);return 0; //结果是0.36倍.}P082 0.2 求各种存款的利息数.#include<stdio.h>#include<math.h>int main(){double p,r,n; //年份和当年利率均有给出.p=1000*(1+5*0.0585);printf("5 years is %lf !\n",p); //1292.5,这是全五年期.lf输出的是double型.p=(1000*(1+2*0.0468));p=(p*(1+3*0.0540));printf("5 years is %lf !\n",p); //1270.76,这是先二年,再三年的.p=(1000*(1+3*0.0540));p=(p*(1+2*0.0468));printf("5 years is %lf !\n",p); //1270.76,这是先三年,再二年的.证明,是一样的.p=1000*pow((1+0.0414),5);printf("5 years is %lf !\n",p); //1224.86,这难道说是,相对的存死期越久越值钱.p=1000*pow((1+0.072/4),4*5);printf("5 years is %lf !\n",p); //1428.74.return 0;}P083 0.3 求几个月要以还贷.#include<stdio.h>#include<math.h>int main(){double m,r=0.01,d=300000,p=6000;m=(log10(p/(p-d*r)))/(log10(1+r));printf("%.1lf",m); //按要求只留一个小数,所以要写%.1lf.return 0;}P084 0.6 字母密码转换,调用函数及临界处理.#include<stdio.h>char printcode(char f){if(((int)f>86&&(int)f<91)||((int)f>118&&(int)f<123)){return(f-26+4); //因为putchar会自动返回,所以改成return,因为这是在函数中,调用需要返回值.}else{return(f+4);}}int main(){char a,b,c,d,e;printf("Please input :\n");a=getchar();b=getchar();c=getchar();d=getchar();e=getchar(); //临界问题.printf("%c%c%c%c%c",printcode(a),printcode(b),printcode(c),printcode(d),printc ode(e));putchar(putcharcode(a));putchar(putcharcode(b));putchar(putcharcode(c));putchar(putcharcode(d));putchar(putcharcode(e));return 0; //注意理解自定义函数的定义,使用,及形参实参的流向.//p84的是计算问题,自己看着办,最后要求小数点后两位,用的是%.2lf 来实现,因为没有要求实部,所以m.n格式中m不写.//p84的是定义问题,第一问,两者都行,但是定义字母时,scanf要写%c来获取,而定义数值时则要用%d来获取.// 第二问,putchar貌似只能输出字符,所以用printf.putchar本身就是字符输出函数啦,字符,有木有!!!字符啊!!尽管它的参数可以是putchar('\101'),效果是输出字符A啊.// 第三问,出现"任何"及"无条件",那么答案明显是"否".可以转换,但要在某此条件下,例如输出和读入时,%c是字母,而%d是数值,看着办.}。
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
func( 10, 11,12);
func(12,12);
}
void func( int a, int b, int c, int d)
{cout<<a<<'\t'<<b<<'\t'<<c<<'\t'<<d<<endl;}
10 15 20 30
10 11 12 4
a+=f(g(a));
b+=f(f(b));
cout<<a<<”\t”<<b;
}
3 2
5.编程题
5.1输入m、n和p的值,求s=的值。注意判断运算中的溢出。
#include<iostream>
using namespace std;
long sum(int,int);
int main(){
long s;
{int c;
a+=a;b+=b;
c=f2( a+b,b+1);
return c;
}
int f2( int a,int b)
{int c;
c=b%2;
return a+c;
}
int main()
{int a=3,b=4;
cout<<f1(a,b)<<endl;
}
15
4.5#include <iostream>
q*=i;
s+=q;
}
return s;
}
5.2使用重载函数编程序分别把两个数和三个数从大到小排列。
#include<iostream>
using namespace std;
void f(int,int,int);
void f(int,int);
int main(){
int a,b,c;
cin>>a>>b;
f(a,b);
cin>>a>>b>>c;
f(a,b,c);
return 0;
}
void f(int a,int b,int c){
int t;
if(a<b){
t=a;a=b;b=t;
}
if(a<c){
t=a;a=c;c=t;
}
if(b<c){
t=b;b=c;c=t;
}
cout<<a<<","<<b<<","<<c<<endl;
{ return (x>y?x:y);}
int main() {
int m(3),n(4);
max(m,n) --;
cout<<m<<”\t”<<n;
}
3 3
4.7 int f(int i) {return ++i;}
int g(int &i) {return ++i;}
int main() {
int a(0),b(0);
A.return语句中的表达式类型决定
B.调用该函数时的主调函数类型决定
C.调用该函数时系统临时决定
D.定义该函数时所指定的函数类型决定
3.3若有函数调用语句:fun(a+b,(x,y),(x,y,z));此调用语句中的实参个数为(A)。
A.3 B.4 C.5 D.6
3.4 C++中,关于默认形参值,正确的描述是(C)。
2.简答题
2.1函数的作用是什么?如何定义函数?什么叫函数原型?
2.2什么叫形式参数?什么叫实际参数?C++函数参数有什么不同的传递方式?请写一个验证程序说明。
2.3 C++函数通过什么方式传递返回值?若返回引用类型时,是否可以返回一个算术表达式?为什么?
2.4变量的生存期和变量作用域有什么区别?请举例说明。
1.4递归程序分两个阶段执行递推,回归。
1.5函数名相同,但对应形参表不同的一组函数称为重载函数,参数表不同是指类型不同或参数个数不同。
1.6内联函数的展开、重载函数的确定均在编译阶段进行。
1.7静态局部变量存储在全局数据区,在程序运行时候建立,生命期为整个程序,如定义时未显式地初始化,则其初值为0。局部变量存储在栈区,在块或函数开始运行时候建立,生命期为块或函数,如定义时未显式地初始化,则其初值为随机数。
cin>>a>>b;
cout<<f(a,b);
return 0;
}
int f(int a,int b){
if(a%b)return f(b,a%b);
return b;
}
5.5输入一个十进制整数,用递归算法实现将该整数转换为n进制(n>1同时n<10)输出。
double add(double,double);
}
5.6用递归函数实现勒让德多项式。并在主函数中求P5(1.4)。
Pn(x)=
#include<iostream>
usingnamespacestd;
doubleP(intn,doublex){
if(n==0)return1;
if(n==1)returnx;
return((2*n-1)*x*P(n-1,x)-(n-1)*P(n-2,x))/n;
int m,n,p;
cin>>m>>n>>p;
s=sum(m,1)+sum(n,3)+sum(p,5);
cout<<s<<endl;
return 0;
}
long sum(int n,int e){
long s=0;
int i,j,q;
for(i=1;i<=n;i++){
q=1;
for(j=1;j<=e;j++)
}
intmain(){
cout<<"P(4,1.5)="<<P(4,1.5)<<endl;
return0;
}
5.7把以下程序中的print()函数改写为等价的递归函数。
#include <iostream>
void print( int w)
{for( int i=1;i<=w;i++)
{for( int j=1;j<=i;j++)
}
void f(int a,int b){
if(a>b)cout<<a<<","<<b<<endl;
else cout<<b<<","<<a<<endl;
}
5.3设计一函数,判断一整数是否为素数。并完成下列程序设计.
(1)求3-200之间的所有素数
(2)在4-200之间,验证歌德巴赫猜想:任何一个充分大的偶数都可以表示为两个素数之和。输出4=2+2 6=3+3。。。。。200=3+197
long convert(long,int);
int main(){
long a,b;
int n;
cin>>a>>n;
b=convert(a,n);
cout<<b<<endl;
return 0;
}
long convert(long a,int n){
if(a<n)return a;
else return convert(a/n,n)*10+a%n;
}
int f( int a)
{int b=0,c=1;
b++;c++;
return(a+pow(b, 2)+c);
}
3 4 5
4.2 #include <iostream>
using namespace std;
void func(int a, int b, int c=3, int d=4);
int main()
1.概念填空题
1.1一个C++程序是由一个或多个函数所组成,即使是最简单的程序,也必须有一个main函数。该函数是程序执行的起点和终点。C++中,函数不允许嵌套定义,允许嵌套调用。
1.2函数执行过程中通过return语句将函数值返回,当一个函数不需要返回值,需要使用void作为类型名。
1.3在C++中,如果函数定义在后,调用在先,需要原型声明。其格式和定义函数时的函数头的形式基本相同,但参数表中形参不是必须的,同时必须以;结尾。
}
5.8定义结构类型Triangle,表示一个矩形,它的两个数据成员length和width分别表示长和宽。定义重载函数add,能完成int,double,Triangle类型数据的相加。其中Triangle类型数据相加的含义是两个Triangle变量的length和width分别相加。
#include<iostream>
using namespace std;
int age( int n)