C++面向对象程序设计(谭浩强)习题答案

C++面向对象程序设计(谭浩强)习题答案,第1张

一、单项选择题(每题1分,共20分)

1、在C语言程序中应包含一个 。

A)语句 B)函数调用 C)主函数D)子函数

2、C程序 构成。

A)由主程序和子程序 B)可以由一个主函数和若干其他函数

C)只能由一个函数即主函数D)可以由若干个主函数和其他函数

3、C语言基本类型包括( )

A) 整型、实型、逻辑型 B) 整型、实型、字符型、逻辑型

C) 整型、字符型、逻辑型D) 整型、实型、字符型

4、逻辑运算符两侧运算对象的数据类型 。

A) 只能是0和1 B) 只能是0或非0正数

C) 只能是整型或字符型数据 D) 可以是任何类型的数据

5、设有定义:log x=-123456L,则能够正确输出变量x值的语句是 。

A)printf("x=%8dL\n",x) B)printf("x=%8dL\n",x)

C)printf("x=%1d\n",x) D)printf("x=%LD",x)

6、printf函数中用到格式符%5s,其中数字5表示输出的字符串占用5列,如果字符串长度小于5,则输出按下列哪种方式进行 。

A)从左起输出字符串 B)按原字符串长度从左到右输出

C)右对齐输出该字符串,左补空格 D)输出错误信息

7、语句while(!e)中的条件!e等价与 。

A)e==0 B)e!=1C)e!=0D)e==1

8、设有程序段

int k=10

while(k=0) k=k-1

则下面描述中正确的是。

A)while循环执行10次 B)循环是无限循环

C)循环体1次也不执行 D)循环体执行1次

9、初始化语句正确的是 。

A)int a[1][4]={1,2,3,4,5} B)float x[3][ ]={{1},{2},{3}}

C)long b[2][3]={{1},{2},{3}} D)double y[ ][3]={{1,2},{3},{4}}

10、若要求:如果字符串s1大于字符串s2,则执行语句1,应当使用 。

A)if(s1>s2) 语句1B)if(strcmp(s1,s2)) 语句1

C)if(strcmp(s2,s1)>0) 语句1 D)if(strcmp(s1,s2)>0) 语句1

11、已知:char str1[10],str2[10]= "Hello! ";则在程序中能够将字符串"Hello! "赋给数组str1的正确语句是 。

A)str1="Hello!" B)strcpy(str1,str2) C) str1=str2 D) strcpy(str2,str1)

12、若有说明:int *p ,m = 5 , n 以下正确的程序段是 。

A)p = &n scanf ("%d" ,&p) B) p = &n scanf ("%d" ,*p)

C) scanf ("%d" , &n) *p = nD) p = &n *p = m

13、下面程序段的运行结果是 。

char *s = "abcde"

s + = 2 printf ("%d" ,s)

A) cde B) 字符'c'C)字符'c'的地址 D)无确定的输出结果

14、设p1和p2是指向同一个字符串的指针变量,c为字符变量,则以下不能正确执行的赋值语句是 。

A) c = *p1 + *p2 B)p2 = c C) p1 = p2D) c = *p1*(*p2)

15、若有以下定义,则对a数组元素地址的正确引用是 。

int a[5] , *p = a

A) p + 5 B) *a + 1 C) &a + 1 D) &a[0]

16、下列说法中错误的是 。

A) 主函数可以放在程序的任何地方。

B) 非主函数总是通过函数调用语句来执行。

C ) C程序的书写格式灵活,一行可以写多个语句。

D) C程序的注释也参加编译并出现在目标程序中。

17、以下说法正确的是。

A) C语言程序总是从第一个定义的函数开始执行。

B) 在C语言程序中,要调用的函数必须在main()函数中定义。

C) C语言程序总是从main()函数开始执行。

D、C语言程序中的main()函数必须放在程序的开始部分。

18、已知字母A的ASCII码为十进制数65,且c2为字符型,则执行语句c2=‘A’+‘6’-‘3’后,c2中的值为 。

A) D B) 68 C) 不确定的值 D) C

19、以下叙述正确的是。

A) 在C程序中,每行只能写一条语句

B) 若a是实型变量,C程序中允许赋值a=10,因此实型变量中允许存放整型数

C) 在C程序中,%是只能用于整数运算的运算符

D) 在C程序中,无论是整数还是实数,都能被准确无误地表示

20、如果已经定义的变量,正确交换变量a、b的是 。

A)a=bb=a B)a=bt=ab=t

C)t=aa=bb=t D)a=a+bb=a-aa=a-b

21、下面输入语句中正确的是 。(设:int a,b,c)

A)input(a,b,c)B)scanf("%d%d%d",&a,&b,&c)

C)scanf(%d,%d,%d,&a,&b,&c)D)scanf("%d,%d,%d",a,b,c)

22、下面有关for循环的正确描述是 。

A)for循环只能用于循环次数已经确定的情况

B)for循环是先执行循环体,后判条件

C)在for循环中,不能用break语句跳出循环

D)for循环的循环体语句中,可以包含多条语句,但必须用花括号括起来

23、C语言中while和do-while循环的主要区别是。

A)do-while的循环体至少执行1次 B)while的循环条件比do-while的循环条件严格

C)do-while允许从外部转到循环体内D)do-while的循环体不能是复合语句

24、已知:int a[10];则对a数组元素的正确引用的是。

A)a[10] B)a[3.5] C)a[5]D)a[10-10]

25、在C语言中,二维数组元素在内存中的存放顺序是 。

A)按行存放 B)按列存放C)由用户定义 D)由函数决定

26、已知:int a[ ][3]={1,2,3,4,5,6,7}则数组a的第一维的大小是 。

A)2 B)3 C)4 D)无法确定

27、以下程序中调用scanf函数给变量a输入数值的方法是错误的,其错误原因是 。

main( )

{ int *p ,*q , a,b

p =&a

printf ("input a:")

scanf ("%d" , *p)

…}

A) *p表示的是指针变量p的地址 B)*p表示的是变量a的值,而不是变量a的地址

C)*p表示的是指针变量p的值 D)*p只能用来说明p是一个指针变量

28、已有定义int k = 2 int *ptr1,*ptr2 且ptr1和ptr2均已指向变量k ,下面不能正确执行的赋值语句是。

A) k = *ptr1+*ptr2 B) ptr2 = k C) ptr1 = ptr2 D) k = *ptr1 *(*ptr2)

29、变量的指针,其含义是指该变量的。

A)值 B)地址C)名 D)一个标志

30、若有语句int *point , a = 4 和point = &a 下面均代表地址的一组选项是 。

A)a , point ,*&a B) &*a ,&a , *point

C) *&point , *point , &a D) &a , &*point ,point

31、在C语言中,回车换行符是()

A. \ n B. \ t C. \ v D. \ b

32、下列字符串不是标识符的是( )

A. sum B. Average C. Day_nightD. M.D.JOHN

33、 在C语言中,下列类型属于构造类型的是( )

A.整型 B.字符型 C.实型D.数组类型

34、设有如下定义:

int x=10,y=5,z

则语句printf(“%d\n”,z=(x+=y,x/y))

的输出结果是( )

A.0 B.1 C.3 D.4

35、在C语言中,语句和数据定义是用( )作为结束标记的

A.句号 B.逗号 C.分号D.括号

36、以下程序的输出结果是()

main( )

{ char c1=’8’,c2=’2’

printf(“%c,%c,%d,%d\n”,c1,c2,c1-c2,c1+c2) }

A.因输出格式不合法,输出出错信息

B.8,2,6,106C.8,2,6,10 D.8,2,5,9

37、两次运行下面的程序,如果从键盘上分别输入6和4,则输出结果是()

main( )

{int x

scanf(“%d”,&x)

if(x++>5) printf(“%d\n”,x)

else printf(“%d\n”,x--)}

A.7和5B.7和4C.6和4

38、有如下程序段:

int k=0

while(k++<=2) printf(“%d\n”,k)

则正确的执行结果是( )

A. 2 B. 0 C.1 D无结果

3 12

4 23

39、变量i的值为3,i的地址为2000,若欲使指针变量p指向变量i,则下列赋值正确的是()

A.&i =3 B.*p=3 C.*p=2000D p=&i

40、下面程序的执行结果是( )

main( )

{int i, *i_pointer

i_pointer=&i

*i_pointer=9

printf(“i=%d”,i)}

A.i=0 B.i=9 C.i值不确定D.程序有错误

41、表达式(int)2.1416的值时( )

A. 2B. 2.1C. 0D. 3

42、下列运算符优先级最高的是( )

A. >B. + C. && D. !=

43、程序段如下:

int k=1

while (k=0) k=k+1

则以下说法正确的是( )

A. while循环执行20次 B. 循环是无限循环

C. 循环体语句一次也不执行 D.循环体语句执行一次

44、C语言容许函数值类型缺省定义,此时该函数值隐含的类型时()

A. float型 B. Int型 C. Long 型 D. Double型

45、在C语言中引用数组元素时,其数组下标的数据类型是( )

A. 整型常量 B. 整型表达式

C. 整型常量和整型表达式 D. 任何类型的表达式

46、以下程序段的输出结果是( )

char str[ ]=”ABCD”, *P=str

printf(“% d \ n”, *( p+4 ))

A. 68B. 0 C. 字符D的地址D. 不确定的值

47、一个C程序的执行是从()

A.本程序中的main函数开始,到main函数结束

B.本程序中的第一个函数开始,到本程序中的最后一个函数结束

C.本程序中的main函数开始,到本程序中的最后一个函数结束

D.本程序中的第一个函数开始,到本程序中的main函数结束

48、关于return语句,下列说法中不正确的是( )

A.函数可以通过return语句获得返回值。

B.没有return语句函数就不能获得返回值。

C.return语句后面可以是常量、变量名或表达式,只要有确定的值

D.C语言中允许函数不返回值

49、按照C语言的规定,下列说法正确的是( )

A.实参可以是常量、变量或表达式,在传递给形参时,要求实参必须有确定的值

B.形参可以是常量、变量或表达式

C.实参可以为任意类型

D.形参与其对应的实参类型要求可以不一致

50、设有int a[ ]={10,11,12},*p=&a[0];则执行完*p++*p+=1后a[0],a[1],a[2]的值依次是 ( )

A.10,11,12B.11,12,12C.10,12,12D.11,11,12

51、C语言中基本数据类型包括 。

A、整型、实型、逻辑型 B、整型、实型、字符型

C、整型、字符型、逻辑型 D、整型、实型、数组 、字符型

52、下列常数中不能作为C语言常量的是 。

A、0xA5B、2.5e-2C、3e2 D、0582

53、下列不属于C语言关键字的是 。

A、default B、void C、structD、external

54、已知int j,i=1执行语句j= -i++后,j的值是 。

A、1B、2C、-1 D、-2

55、已知int i,a执行语句i=(a=2*3,a*5),a+6后,i的值是。

A、6B、12 C、30 D、36

56、已知int x=1,y=2,z执行语句z=x>y?++x:++y后,z的值是 。

A、1B、2C、3D、4

57、不能进行++和—运算的数据类型是 。

A、指针 B、doubleC、int D、long

58、为了明确表示不带回函数值,定义函数时函数名前用 。

A、intB、void C、struct D、static

59、若有 int a[2][3]={1, 3, 5, 7, 9, 11};则a[1][2]的值为 。

A、3 B、5 C、11 D、9

60、对于存储类型为 的变量,只有使用时才占用内存单元。

A、static B、externC、auto D、前面都不对

二、填空题(每空1分,共20分)

1、用C语言编写的程序,编译成功后生成的文件扩展名是,连接成功后生成的文件扩展名是。

2、用汇编语言写的程序必须通过程序翻译后才能执行,而高级语言写的源程序可以通过程序翻译一句执行一句的方式,也可以通过程序一次翻译产生目标程序,然后执行。

3、若x和n均是int型变量,且x和n的初值均为5,则计算下列表达式后x的值为 ,n的值为 。 x+=n++

4、若a是int型变量,则计算下面表达式后a的值为 。a=25/3%3

5、若for循环用以下形式表示:for(表达式1表达式2表达式3) 循环体语句,则执行语句for(i=0i<3i++) printf("*")时,表达式1执行 次,表达式3执行 次。

6、在C程序中,从开始到结束的内容为注释信息,并且注释信息(可以/不可以)出现在程序的任何地方。

7、C程序有且只有一个主函数,它的函数名是,主函数(可以/不可以)调用任何非主函数,任何非主函数(可以/不可以)调用主函数。

8、若有定义:char c=‘\010’;则变量c中包含的字符个数为______。

9、鸡兔共有30只,脚共有90个,下面程序段是计算鸡兔各有多少只,请填空。

for(x=1x<=29x++)

{y=30-x

if() printf("%d,%d\n",x,y) }

10、一个C源程序至少包括_________个函数,即_______函数。

11、若有说明int i,j,k则表达式i=10,j=20,k=30,k*=i+j的值为_______________。

12、语句"printf("%x,%o",16,12)"的输出结果是 。

13、开发一个C程序的步骤是,,, 。

14、一个C程序中必须包含一个且只包含一个 函数。

15、C语言中每个基本语句都以结束。

16、C语言规定,对程序中用到的变量,必须先,后 。

17、单精度浮点型变量和双精度浮点型变量的类型标识符分别为 和 。

18、C语言中唯一的三元运算符是,运算优先级最低的运算符是 。

19、 函数可以嵌套,不能嵌套 。

20、欲将1,2分别输入给x,y,则执行scanf(“x=%d,y=%d”,&x,&y)

语句时的输入格为 。

21、若x=2,y=3,则执行x*=y+1语句后,x的值为 。

22、 是C程序的基本组成单位。

23、在循环语句中执行了break语句,则 。

24、C语言规定,凡不加类型说明的函数,一律按。

25、函数调用的三种方式: 、 、。

26、在函数调用中给出的参数称 ,在函数定义中给出的参数称 。

27、C语言中自动在每个字符串的末尾添加一个 。

28、if与else的配对关系中,else总是与 的if配对。

29、文件的打开使用 函数;文件的关闭使用 函数。

30、若int x [ ]={1, 3, 5},* p=x;则*(p++)的值为。

31、一个函数由两部分组成,他们是 和 。

32、C语言是通过来进行输入和输出的。

33、C语言的数据类型有四大类,他们是 、 、 、 。

34、当执行以下程序段后,i的值为 、j的值为 、k的值为 。

int a,b,c,d,i,j,k

a=10 b=c=d=5 i=j=k=0

for( a>b++b) i++

while (a>++c) j++

do k++ while (a>d++)

35、若有以下定义:double w[10];则w数组元素下标的上限是 ,下限是。

36、Break语句只能用于和 语句。

37、在循环中,continue语句与break语句的区别是:continue语句只是 ,break 是 。

38、若有说明int i,j,k则表达式i=10,j=20,k=30,k*=i+j的值为。

39、语句"printf("%x,%o",16,12)"的输出结果是 。

三、程序填空

1、下面程序的功能是在输入的一批正整数中求出最大者,输入0结束循环。请填空。

main()

{int a,max=0

scanf("%d",&a)

while( )

{ if (max<a) max=a

scanf("%d",&a)}

printf("%d",max)}

2、以下程序的功能是:从键盘上输入若干学生的成绩,统计并输出最高成绩和最低成绩,当输入负数时结束输入。请填空。

main()

{ float x,amax,amin

scanf(“%f”,&x)

amax=xamin=x

while()

{if ( x>amax ) amax=x

else if (x<amin)

}

printf(“\namax=%f\namin=%f\n”,amax,amin)}

3、输入若干字符,分别统计数字字符的个数、英文字母的个数,当输入换行符时输出统计结果,运行结束。

#include <stdio.h>

void main()

{ char ch

while(( )!='\n')

{if(ch>='0'&&ch<='9') s1++

if((ch>='a' &&ch<='z')|| ) s2++}

printf(“%d,%d\n”,s1,s2)}

4、findmax返回数组s中最大元素的下标,数组中元素的个数由t传入,请填空。

findmax(int s[ ], int t)

{ int k,p

for(p=0, k=p p<t p++)

if (s[p]>s[k])

return }

5、以下程序的功能是:从键盘上输入若干学生的成绩,统计并输出最高成绩和最低成绩,当输入负数时结束输入。请填空。

main()

{ float x,amax,amin

scanf(“%f”,&x)

amax=xamin=x

while( )

{ if ( x>amax ) amax=x

else if (x<amin)

}

printf(“\namax=%f\namin=%f\n”,amax,amin)}

6、输入若干字符,分别统计数字字符的个数、英文字母的个数,当输入换行符时输出统计结果,运行结束。

#include <stdio.h>

void main()

{ char ch

_________

while(( )!='\n')

{if(ch>='0'&&ch<='9') s1++

if((ch>='a' &&ch<='z')|| ) s2++}

printf(“%d,%d\n”,s1,s2)}

7、下面程序的功能是求出用数字0至9可以组成多少个没有重复数字的三位数。请填空。

main()

{int i,j,k,count=0

for(i=1i<=9i++)

for(j=0j<=9j++)

if( ) continue

else for(k=0k<=9k++)

if( ) count++

printf("%d",count)}

8、输出3——100之间的所有素数

#include “stdio.h”

main()

{ int i,j

for(i=3i<=100i++)

{for(j=2j<=i-1j++)

if( ) break

if()

printf(“%4d”,i)

} }

9、将字符串s中所有的字符‘c’删除

#include “stdio.h”

main()

{ char s[80]

int i,j

for(i=j=0s[i]!=‘\0’i++)

if(s[i]!=‘c’)

puts(s) }

10、用选择法对10个整数排序(从小到大)

main()

{int i,j,min,temp,a[11]

for(i=1i<=10i++)

for(i=1i<=9i++)

{min=i

for( j<=10j++)

if(a[min]>a[j])

temp=a[i]

a[min]=temp}

for(i=1i<=10i++)

}

四、判断题(每题1分,共20分)

1、若有说明int c;则while(c=getchar());是正确的C语句。 ( )

2、int i,*p=&i;是正确的C说明。 ( )

3、7&3+12的值是15。 ( )

4、在C语言中,函数既可嵌套调用又可嵌套定义。 ( )

5、for( )S中的语句S必执行无穷多次。 ( )

6、unsigned 和

--------------------------------------------------------------------------------

作业名称:面向对象程序设计

作业总分:100

学员姓名:mj07b201 学员成绩:95

标准题总分:100 标准题得分:95

详细信息:

题号:1 题型:单选题 本题分数:1

内容:

一个类的友元函数能够访问该类的( )

选项:

A、A)私有成员

B、B)保护成员

C、C)公有成员

D、D)所有成员

学员答案:

D

题号:2 题型:单选题 本题分数:1

内容:

下面关于类和对象的描述中,错误的是( )

选项:

A、A)类就是C语言中的结构体类型,对象就是C语言中的结构体变量

B、B)类和对象之间的关系是抽象和具体的关系

C、 C)对象是类的实例,一个对象必须属于一个已知的类

D、 D)类是具有共同行为的若干对象的统一描述体

学员答案:

A

题号:3 题型:单选题 本题分数:1

内容:

以下各选项组中,均是C++语言关键字的组是( )

选项:

A、A) public operator this

B、 B)shod string static

C、 C)it while>=

D、 D)private cout printf

学员答案:

A

题号:4 题型:单选题 本题分数:2

内容:

设int a=10,b=11,c=12,表达式(a+b) 的值为( )

选项:

A、A)2

B、 B)0

C、 C)-2

D、 D)1

学员答案:

B

题号:5 题型:单选题 本题分数:1

内容:

下列描述正确的是( )

选项:

A、A)表示m>n为true或mn&&m

B、 B)switch语句结构中必须有default语句

C、 C)if语句结构中必须有else语句

D、 D)如果至少有一个 *** 作数为true,则包含“‖”运算符的表达式为true

学员答案:

D

题号:6 题型:单选题 本题分数:1

内容:

下面关于数组的描述错误的是( )

选项:

A、A)在C++语言中数组的名字就是指向该数组第一个元素的指针

B、 B)长度为n的数组,下标的范围是0-n-1

C、 C)数组的大小必须在编译时确定

D、 D)数组只能通过值参数和引用参数两种方式传递给函数

学员答案:

D

题号:7 题型:单选题 本题分数:2

内容:

下面程序错误的语句是( )①#include ②void main() ③{ ④int*p=new int[1] ⑤p=9 ⑥cout <<*p< ⑦delete[]p ⑧}

选项:

A、A)④

B、B)⑤

C、C)⑥

D、D)⑦

学员答案:

B

题号:8 题型:单选题 本题分数:2

内容:

下面的哪个选项不能作为函数的返回类型?( )

选项:

A、A)void

B、B)int

C、C)new

D、D)long

学员答案:

C

题号:9 题型:单选题 本题分数:1

内容:

不能作为重载函数的调用的依据是( )

选项:

A、A)参数个数

B、 B)参数类型

C、 C)函数类型

D、 D)函数名称

学员答案:

B

题号:10 题型:单选题 本题分数:2

内容:

下列程序的输出结果为( ),以下是引用片段: #include<iostream. h> int func(int n) { if〔n<1)return 1 else return n+func(n-1): return 0 } void main() { cout<选项:

A、A) 0

B、B)10

C、C)15

D、D)16

学员答案:

D

题号:11 题型:单选题 本题分数:1

内容:

在C++语言中,数据封装要解决的问题是( )

选项:

A、A)数据的规范化

B、 B)便于数据转换

C、 C)避免数据丢失

D、 D)防止不同模块之间数据的非法访问

学员答案:

D

题号:12 题型:单选题 本题分数:2

内容:

以下程序中,错误的行是 ①#include ②class A ③{ ④ public: ⑤ int n=2: ⑥ A( int val){cout<选项:

A、A)⑤

B、B)⑥

C、C)⑦

D、D)⑩

学员答案:

A

题号:13 题型:单选题 本题分数:1

内容:

下面有关重载函数的说法中正确的是()

选项:

A、A)重载函数必须具有不同的返回值类型

B、 B)重载函数形参个数必须不同

C、C)重载函数必须有不同的形参列表

D、D)重载函数名可以不同

学员答案:

C

题号:14 题型:单选题 本题分数:1

内容:

下列关于构造函数的描述中,错误的是()

选项:

A、A)构造函数可以设置默认参数

B、B)构造函数在定义类对象时自动执行

C、C)构造函数可以是内联函数

D、D)构造函数不可以重载

学员答案:

D

题号:15 题型:单选题 本题分数:1

内容:

下面描述中,表达错误的是()

选项:

A、A)公有继承时基类中的public成员在派生类中仍是public的

B、 B)公有继承是基类中的private成员在派生类中仍是private的

C、C)公有继承时基类中的protected成员在派生类中仍是protected的

D、 D)私有继承时基类中的public成员在派生类中是private的

学员答案:

B

题号:16 题型:单选题 本题分数:2

内容:

在进行完任何C++流的 *** 作后,都可以用C++流的有关成员函数检测流的状态;其中只能用于检测输入流状态的 *** 作函数名称是()

选项:

A、A)fail

B、B)eof

C、 C)bad

D、D)good

学员答案:

B

题号:17 题型:单选题 本题分数:1

内容:

下列关于C++语言类的描述中错误的是( )

选项:

A、A)类用于描述事物的属性和对事物的 *** 作

B、 B)类与类之间通过封装而具有明确的独立性

C、C)类与类之间必须是平等的关系,而不能组成层次结构

D、 D)类与类之间可以通过一些方法进行通信和联络

学员答案:

C

题号:18 题型:单选题 本题分数:1

内容:

以下叙述中正确的是( )

选项:

A、A)构成C++语言程序的基本单位是类

B、 B)可以在一个函数中定义另一个函数

C、 C) main()函数必须放在其他函数之前

D、 D)所有被调用的函数一定要在调用之前进行定义

学员答案:

A

题号:19 题型:单选题 本题分数:2

内容:

己知有定义 以下是引用片段: const int D=5 int i=1 double f=0.32: char c=15 则下列选项错误的是( )

选项:

A、A)++i

B、 B)D--

C、 C)C++

D、 D)--f

学员答案:

B

题号:20 题型:单选题 本题分数:2

内容:

下面程序的功能是把316表示为两个加数的和,使两个加数分别能被13和11整除,在划线处应填入的选项是( ),以下是引用片段: void main() { int i=0,j,k do{i++k=316-13*i}while( ) j=k/11 cout<<”316=13*”< }

选项:

A、A)k/11

B、B)k% 11

C、 C)k/11==0

D、D)k%11==0

学员答案:

B

题号:21 题型:单选题 本题分数:2

内容:

设有数组定义:char array[]=”China",则数组array所占的空间为( )

选项:

A、A)4个字节

B、B)5个字节

C、C) 6个字节

D、D)7个字节

学员答案:

C

题号:22 题型:单选题 本题分数:2

内容:

若已定义: int a[]={0,1,2,3,4,5,6,7,8,9},*P=a,i 其中O≤i≤9,则对a数组元素不正确的引用是( )

选项:

A、A)a[p-a]

B、 B)*(&a[i])

C、C)p[i]

D、D)a[10]

学员答案:

D

题号:23 题型:单选题 本题分数:2

内容:

函数fun的返回值是( ) 以下是引用片段: fun(char*a,char*b) { int num=0,n=0 while(*(a+num)!=‘\0’)num++ while(b[n]){*(a+num)=b[n]num++n++} return num }

选项:

A、A)字符串a的长度

B、B)字符串b的长度

C、C)字符串a和b的长度之差

D、D)字符串a和b的长度之和

学员答案:

D

题号:24 题型:单选题 本题分数:2

内容:

下面程序的结果为( ),以下是引用片段: void main() { int i int a[3][3]={1,2,3,4,5,6,7,8,9} for(i=0i<3i++) cout<选项:

A、A)1 5 9

B、B)7 5 3

C、C)3 5 7

D、D) 5 9 1

学员答案:

B

题号:25 题型:单选题 本题分数:1

内容:

下列描述中哪个是正确的( )。

选项:

A、A)私有派生的子类无法访问父类的成员

B、 B)类A的私有派生子类的派生类,C无法初始化其祖先类A对象的属性,因为类A的成员对类C是不可访问的

C、 C)私有派生类不能作为基类派生子类

D、 D)私有派生类的所有子孙类将无法继续继承该类的成员

学员答案:

B

题号:26 题型:单选题 本题分数:1

内容:

下列关于构造函数说法不正确的是( )

选项:

A、A)构造函数必须与类同名

B、 B)构造函数可以省略不写

C、 C)构造函数必须有返回值

D、 D)在构造函数中可以对类中的成员进行初始化

学员答案:

C

题号:27 题型:单选题 本题分数:1

内容:

如果友元函数重载一个运算符时,其参数表中没有任何参数则说明该运算符是( )

选项:

A、A)一元运算符

B、B)二元运算符

C、 C)选项A)和选项B)都可能

D、D)重载错误

学员答案:

D

题号:28 题型:单选题 本题分数:1

内容:

在重载一个运算符时,如果其参数表中有一个参数,则说明该运算符是( )

选项:

A、A)一元成员运算符

B、B)二元成员运算符

C、C)一元友元运算符

D、D)选项B)和选项C)都可能

学员答案:

D

题号:29 题型:单选题 本题分数:2

内容:

建立派生类对象时,3种构造函数分别是a(基类的构造函数)、b(成员对象的构造函数)、c(派生类的构造函数)这3种构造函数的调用顺序为( )

选项:

A、A)abc

B、 B)acb

C、 C)cab

D、 D)cba

学员答案:

A

题号:30 题型:单选题 本题分数:2

内容:

下面关于虚函数的描述,错误的是( )

选项:

A、A)在成员函数声明的前面加上virtual修饰,就可把该函数声明为虚函数

B、 B)基类中说明了虚函数后,派生类中对应的函数也必须说明为虚函数

C、 C)虚函数可以是另一个类的友元函数,但不能是静态成员函数

D、 D)基类中说明的纯虚函数在其任何派生类中都必须实现

学员答案:

B

题号:31 题型:单选题 本题分数:2

内容:

下面关于模板的描述,错误的是( )

选项:

A、A)函数模板和类模板的参数可以是任意的数据类型

B、 B)类模板不能直接使用,必须先实例化为相应的模板类.然后定义了模板类的对象后才能使用

C、 C)函数模板不能直接使用,需要实例化为模板函数后才能使用

D、 D)类模板的成员函数都是模板函数

学员答案:

A

题号:32 题型:单选题 本题分数:2

内容:

语句ofstream f(”SALARY. DAT",ios::app iios::binary)的功能是建立流对象f,试图打开文件SAL:aRY. D AT并与之连接,并且( )

选项:

A、A)若文件存在,将文件写指针定位于文件尾

B、若文件不存在,建立一个新文件

C、 B)若文件存在,将其置为空文件

D、若文件不存在,打开失败

E、 C)若文件存在,将文件写指针定位于文件首

F、若文件不存在,建立一个新文件

G、 D)若文件存在,打开失败

H、若文件不存在,建立一个新文件

学员答案:

A

题号:33 题型:单选题 本题分数:2

内容:

下面程序的运行结果是( ) 以下是引用片段:#include void main(){ int num=1int &ref=numref=ref+2cout<选项:

A、A)13

B、B)16

C、C)36

D、D)33

学员答案:

C

题号:34 题型:单选题 本题分数:2

内容:

设有定义int xfloat v,则10+x+v值的数据类型是( )

选项:

A、A)int

B、B)double

C、C)float

D、D)不确定

学员答案:

C

题号:35 题型:单选题 本题分数:2

内容:

下列程序的执行结果为( ) 以下是引用片段:#include void main() { int a=3,b=0int*p=&ab=+a++cout<<*p<<","<选项:

A、A)3,4

B、B)4,3

C、C)3,4

D、D)4,4

学员答案:

B

题号:36 题型:单选题 本题分数:2

内容:

下面程序的运行结果为( ) 以下是引用片段:#include void main() { for(int a=0,x=0!x&&a<=10a++) { a++}cout<选项:

A、A)10

B、B)11

C、C)12

D、D) 0

学员答案:

C

题号:37 题型:单选题 本题分数:2

内容:

下列程序的输出结果为( ) 以下是引用片段:#include void main() { char *a[]={"hello","the","world"}char**pa=apa++cout<<*pa}

选项:

A、A)hello

B、 B)the

C、 C)world

D、 D)hellotheworld

学员答案:

B

题号:38 题型:单选题 本题分数:1

内容:

决定C++语言中函数的返回值类型的是( )

选项:

A、A) return语句中的表达式类型

B、 B)调用该函数时系统随机产生的类型

C、 C)调用该函数时的主调用函数类型

D、 D)在定义该函数时所指定的数据类型

学员答案:

D

题号:39 题型:单选题 本题分数:2

内容:

下列程序的运行结果为( )以下是引用片段: #includevoid print(double a){cout<<++a} void print(int a,int b) { cout<A、A)1.2 34

B、 B)2.2 34

C、 C)1.2 43

D、 D)2.2 43

学员答案:

D

题号:40 题型:单选题 本题分数:1

内容:

对类成员访问权限的控制,是通过设置成员的访问控制属性实现的,下列不是访问控制属性的是( )

选项:

A、A)公有类型

B、 B)私有类型

C、 C)保护类型

D、 D)友元类型

学员答案:

D

题号:41 题型:单选题 本题分数:2

内容:

下面程序的运行结果为( ) 以下是引用片段: #include class A { public: A(){cout<<"1"} ~A(){cout<<"2"} }class B:public A { public: B(){cout<<"3"} ~B(){cout<<"4"} }void main() { B b}

选项:

A、A)1234

B、 B)1324

C、 C)1342

D、 D)3142

学员答案:

C

题号:42 题型:单选题 本题分数:2

内容:

下列关于多态性的描述,错误的是( )

选项:

A、A)C++语言的多态性分为编译时的多态性和运行时的多态性

B、 B)编译时的多态性可通过函数重载实现

C、 C)运行时的多态性可通过模板和虚函数实现

D、 D)实现运行时多态性的机制称为动态绑定

学员答案:

C

题号:43 题型:单选题 本题分数:2

内容:

当使用fstream流类定义一个流对象并打开一个磁盘文件时,文件的隐含打开方式为( )

选项:

A、A)ios::in

B、 B)ios::out

C、 C)ios::in|ios::out

D、 D)以上都不对

学员答案:

D

题号:44 题型:单选题 本题分数:2

内容:

下列程序的运行结果是( ) 以下是引用片段: #include class A { int apublic: A(){a=0} A(int as) { a=ascout<选项:

A、A 23

B、B 12

C、 C 35

D、D 25

学员答案:

B

题号:45 题型:单选题 本题分数:2

内容:

下面程序的输出结果是( ) 以下是引用片段: #include class example { int apublic: example(int b){a=b++} void print(){a=a+1cout<A、A)2 2

B、B)4 3

C、C)4 2

D、D)3 2

学员答案:

C

题号:46 题型:单选题 本题分数:2

内容:

在派生类中重新定义虚函数时必须在( )方面与基类保持一致。

选项:

A、A 、 参数个数

B、B 、 参数名字

C、C 、 *** 作内容

D、D 、 赋值

学员答案:

A

题号:47 题型:单选题 本题分数:2

内容:

C++ 类体系中,不能被派生类继承的有( )。

选项:

A、A 、 转换函数

B、B 、 构造函数

C、C 、 虚函数

D、D 、 静态成员函数

学员答案:

B

题号:48 题型:单选题 本题分数:2

内容:

下列虚基类的声明中正确的是( )

选项:

A、A 、 class virtual B: public A

B、B 、 class B: virtual public A

C、C 、 class B: public A virtual

D、D 、 virtual class B: public A

学员答案:

B

题号:49 题型:单选题 本题分数:1

内容:

C++语言是从早期的C语言逐渐发展演变而来的.与C语言相比,它在求解问题方法上进行的最大改进是( )

选项:

A、A)面向过程

B、B)面向对象

C、C)安全性

D、D)复用性

学员答案:

B

题号:50 题型:单选题 本题分数:1

内容:

C++语言的跳转语句中,对于break和continue说法正确的是()

选项:

A、A)break语句只应用与循环体中

B、B)continue语句只应用与循环体中

C、C)break是无条件跳转语句,continue不是

D、D)break和continue的跳转范围不够明确,容易产生问题

学员答案:

B

题号:51 题型:单选题 本题分数:2

内容:

下列关于模板的说法正确的是( )

选项:

A、A)模板的实参在任何时候都可以省略

B、B)类模板与模板类所指的是同一概念

C、 C)类模板的参数必须是虚拟类型的

D、D)类模板中的成员函数全部都是模板函数

学员答案:

D

题号:52 题型:单选题 本题分数:2

内容:

表示在输出时显示小数位,和在文件输入时判断文件尾的函数分别是( )

选项:

A、A) showbase()和eof()

B、B)showpoint()和eof()

C、 C)showpoint()和bad()

D、D)showpoint()和good()

学员答案:

B

题号:53 题型:单选题 本题分数:2

内容:

若定义int k=7,x=12,则值为3的表达式是( )

选项:

A、A)x%=(k%=5)

B、B)x%=(k-k%5)

C、 C)x%=k-k%5

D、D)(x%=k)-(k%=5)

学员答案:

D

题号:54 题型:单选题 本题分数:2

内容:

在位运算中, *** 作数每右移一位,其结果相当于( )

选项:

A、A) *** 作数乘以2

B、B) *** 作数除以2

C、C) *** 作数乘以4

D、D) *** 作数除以4

学员答案:

B

题号:55 题型:单选题 本题分数:2

内容:

有以下结构体说明和变量的定义,且指针p指向变量a,指针q指向变量b。则不能把节点b连接到节点a 之后的语句是( ), 以下是引用片段: struct node { char data struct node*next }a,b,*p=&a,*q=&b

选项:

A、A)a. next=q

B、 B)p. next=&b

C、 C)p->next=&b

D、 D)(*p).next=q

学员答案:

B

题号:56 题型:单选题 本题分数:2

内容:

下面程序的运行结果为( ) 以下是引用片段: #include class A { int numpublic: A(int i){num=i} A(A &a){num=a. num++} void print(){cout<选项:

A、A)11

B、 B)12

C、 C)21

D、 D)22

学员答案:

C

题号:57 题型:单选题 本题分数:2

内容:

如果类A被说明成类B的友元,则( )

选项:

A、A)类A的成员即类B的成员

B、 B)类B的成员即类A的成员

C、 C)类A的成员函数不得访问类B的成员

D、 D)类B不一定是类A的友元

学员答案:

D

题号:58 题型:单选题 本题分数:2

内容:

可以用p.a的形式访问派生类对象P的基类成员a,其中a是( )

选项:

A、A)私有继承的公有成员

B、 B)公有继承的私有成员

C、 C)公有继承的保护成员

D、 D)公有继承的公有成员

学员答案:

D

题号:59 题型:单选题 本题分数:2

内容:

for(int x=0,y=0!x&&y<=5y++)语句执行循环的次数是()

选项:

A、A)0

B、 B)5

C、 C)6

D、 D)无次数

学员答案:

C

题号:60 题型:单选题 本题分数:2

内容:

考虑函数原型void test(int a,int b=7,char="*"),下面的函数调用中,属于不合法调用的是()

选项:

A、A)test(5)

B、 B)test(5,8)

C、 C)test(6,"#")

D、 D)test(0,0."*")

学员答案:

C

记得给我分啊

这里有第一章的:

谭浩强C++课后习题答案

1.请根据你的了解,叙述C++ 的特点。C++ 对C有哪些发展?

【解】 略。

2.一个C++的程序是由哪几部分构成的?其中的每一部分起什么作用?

【解】 略。

3.从拿到一个任务到得到最终结果,一般要经过几个步骤?

【解】 略。

4.请说明编辑、编译、连接的作用。在编译后得到的目标文件为什么不能直接运行?

【解】 编译是以源程序文件为单位进行的,而一个完整的程序可能包含若干个程序文件,在分别对它们编译之后,得到若干个目标文件(后缀一般为.obj),然后要将它们连接为一个整体。此外,还需要与编译系统提供的标准库相连接,才能生成一个可执行文件(后缀为.exe)。不能直接运行后缀为.obj的目标文件,只能运行后缀为.exe的可执行文件。

5.分析下面程序运行的结果。

#include <iostream>

using namespace std

int main( )

{

cout<<" This "<<" is "

cout<<" a "<<" C++ "

cout<<"program. " <<endl

return 0

}

【解】 输出的结果为

ThisisaC++program.

6.分析下面程序运行的结果。

#include <iostream>

using namespace std

int main( )

{

int a,b,c

a=10

b=23

c=a+b

cout<<" a+b="

cout<<c

cout<<endl

return 0

}

【解】 前两个cout语句在输出数据后不换行,第3个cout语句输出一个换行,因此输出的结果为

a+b=33

7.分析下面程序运行的结果。请先阅读程序写出程序运行时应输出的结果,然后上机运行程序,验证自己分析的结果是否正确。以下各题同。

#include <iostream>

using namespace std

int main( )

{

int a,b,c

int f(int x,int y,int z)

cin>>a>>b>>c

c=f(a,b,c)

cout<<c<<endl

return 0

}

int f(int x,int y,int z)

{

int m

if (x<y) m=x

 else m=y

if (z<m) m=z

return(m)

}

【解】 程序的作用是:输入3个整数,然后输出其中值最小的数。在主函数中输入3个整数,然后调用f函数,在f函数中实现找最小的整数,用if语句比较两个数,将小者存放在变量m中,经过两个if语句的比较,m中存放的是3个整数中最小的数。运行情况如下:

1 5 3↙(输入3个整数)

1 (输出其中最小的数)

8.在你所用的C++系统上,输入以下程序,进行编译,观察编译情况,如果有错误,请修改程序,再进行编译,直到没有错误,然后进行连接和运行,分析运行结果。

int main( )

{

int a,b

c=a+b

cout >>" a+b=" >>a+b

}

【解】 上机编译出错,编译出错信息告知在第2行出错,经检查,发现第1行的末尾多了一个分号,编译系统无法理解第2行的花括号,导致报告第2行出错。将第1行的末尾的分号去掉,重新编译,编译出错信息告知在第5行和第6行出错。第5行出错原因是cout未经声明,因为cout不是C++语言提供的系统的关键字,而是输出流的对象,必须使用头文件iostream。第6行出错原因是main是int型函数,应返回一个整型值。将程序改为

#include <iostream>

int main( )

{

int a,b

c=a+b

cout >>" a+b=" >>a+b

return 0

}

重新编译。编译出错信息告知在第5行和第6行出错。第5行出错原因是变量c未定义,第6行出错原因是cout未经声明,说明#include <iostream>命令行未能起作用,原因是未指明命名空间。将程序改为

#include <iostream>

using namespace std

int main( )

{

int a,b,c

c=a+b

cout>>" a+b=" >>a+b

return 0

}

重新编译。编译出错信息告知在第7行出错,经检查,是“>>”用得不当,“>>”是提取运算符,应与cin联合使用,用来从输入流中提取数据,输出时应该用插入运算符“<<”。把两处“>>”都改为“<<”,再重新编译,发现没有error错误,但有两个警告(warning),原因是定义了a和b,但未对它们赋值。应增加赋值语句或输入语句,使a和b获得值,将程序改为

#include <iostream>

using namespace std

int main( )

{

int a,b,c

cin>>a>>b

c=a+b

cout>>" a+b=" >>a+b

return 0

}

重新编译,没有编译错误,能通过编译和连接,可以正常运行,在Visual C++ 6.0环境下运行时屏幕显示如下:

5 9↙

a+b=14Press any key to continue

显然这样的输出不理想,“Press any key to continue”是Visual C++系统在输出了运行结果后自动显示的一个信息,告诉用户“如果想继续工作,请按任何一个键”。当用户按任何一个键后,显示运行结果的窗口消失,屏幕显示回到Visual C++的主窗口,显示出源程序和编译信息。

为了解决以上输出不理想的情况,可以在最后一个输出语句中增加输出一个换行符。最后的程序如下:

#include <iostream>

using namespace std

int main( )

{

int a,b,c

cin>>a>>b

c=a+b

cout<<"a+b="<<a+b<<endl

return 0

}

运行时屏幕显示如下:

5 9↙

a+b=14

Press any key to continue

这就完成了程序的调试。

这里对本题的调试过程作了比较详细的分析,以便使读者对如何调试程序有比较具体而清晰的了解。需要说明:

(1)编译系统给出的编译出错信息,只是提示性的,引导用户去检查错误,用户必须根据程序的上下文和编译出错信息,全面考虑,找出真正出错之处。例如编译出错信息通知第2行出错,其实可能是第1行出错。

(2)有时,有的错误开始时未被检查出来并告知用户(例如未定义变量c),由于其他错误未解决,掩盖了这个错误。当解决了其他错误后,这个错误会被检查出来。有时在调试过程中会不断检查出新的错误,这是不奇怪的。一一处理,问题会迎刃而解。

(3)为了说明调试过程,这里全部依靠计算机系统来检查错误,其实有些明显的错误,完全可以由人工查出,这样可以提高调试效率。由人工在纸面或屏幕上检查错误,称为静态查错,用计算机编译系统检查错误,称为动态查错。建议尽量先用静态查错的方法排除错误,只有人工检查不出来的错误才让计算机检查。

9.输入以下程序,进行编译,观察编译情况,如果有错误,请修改程序,再进行编译,直到没有错误,然后进行连接和运行,分析运行结果。

#include <iostream>

using namespace std

int main( )

{

int a,b

c=add(a,b)

cout<<"a+b="<<c<<endl

return 0

}

int add(int x,int y)

{

z=x+y

retrun(z)

}

【解】 发现7个错误:

(1)对add函数未声明就调用,应在main函数中对add函数进行声明。

(2)定义add函数时,函数首行末尾不应有分号。

(3)变量c未经定义。

(4)add函数中的变量z未经定义。

(5)第6行末尾少了一个分号。

(6)add函数中的retrun拼写错误,应为return。编译系统把retrun作为未声明的标识符而报错,因为retrun(z)会被认为是函数调用的形式。

(7)变量a和b未被赋值。

改正后的程序如下:

#include <iostream>

using namespace std

int main( )

{int add(int x,int y)

int a,b,c

cin >>a >>b

c=add(a,b)

cout <<" a+b=" <<c <<endl

return 0

}

int add(int x,int y)

{int z

z=x+y

return(z)

}

运行情况如下:

5 8↙

13

10.输入以下程序,编译并运行,分析运行结果。

#include <iostream>

using namespace std

int main( )

{ void sort(int x,int y,int z)

int x,y,z

cin >>x >>y >>z

sort(x,y,z)

return 0

}

void sort(int x, int y, int z)

{

int temp

if (x>y) {temp=xx=yy=temp} //{ }内3个语句的作用是将x和y的值互换

if (z<x) cout <<z <<',' <<x <<',' <<y <<endl

else if (z<y) cout <<x <<',' <<z <<',' <<y <<endl

else cout <<x <<',' <<y <<',' <<z <<endl

}

请分析此程序的作用。sort函数中的if语句是一个嵌套的if语句。

运行时先后输入以下几组数据,观察并分析运行结果。

① 3 6 10↙

② 6 3 10↙

③ 10 6 3↙

④ 10,6,3↙

【解】 程序的作用是对输入的3个整数按由小到大的顺序进行排序。sort函数中的第1个if语句的作用是先将x和y排序,使x小于或等于y。第2个if语句是一个嵌套的if语句,先比较z和x,如果z<x,显然由小到大的顺序应当是z,x,y,按此顺序输出;如果z不小于x,而小于y,显然由小到大的顺序应当是x,z,y,按此顺序输出;如果z既不小于x,又不小于y,显然由小到大的顺序应当是x,y,z,按此顺序输出。

按题目要求分别输入以下几组数据,运行结果如下:

① 3 6 10↙

3,6,10

② 6 3 10↙

3,6,10

③ 10 6 3↙

3,6,10

④ 10,6,3↙

-858993460,-858993460,10

以上是在Visual C++ 6.0环境下运行的情况,前3次运行正常,表明当输入不同的数据时,程序能实现由小到大的排序功能。第4次运行的结果显然不正常,这是由于输入数据时出了问题,本来要求在输入数据时,数据之间以空格或换行相隔,而现在却以逗号相隔,只有第一个整数能正常赋给变量x,第二和第三个数据均无法正常赋给变量y和z,y和z的值来自输入流中相应字节的内容。

11.求2个或3个正整数中的最大数,用带有默认参数的函数实现。

【解】 可以编写出以下程序:

#include <iostream>

using namespace std

int main( )

{int max(int a,int b,int c=0)

int a,b,c

cin >>a >>b >>c

cout <<" max(a,b,c)= " <<max(a,b,c) <<endl

cout <<" max(a,b)= " <<max(a,b) <<endl

return 0

}

int max(int a,int b,int c)

{if(b>a) a=b

if(c>a) a=c

return a

}

运行情况如下:

13 5 76↙

max(a,b,c)=76 (从3个数中找最大者)

max(a,b)=13 (从前2个数中找最大者)

如果想从3个数中找大者,可以在调用时写成“max(a,b,c)”形式,如果只想从2个数中找大者,则在调用时写成“max(a,b)”形式,此时c自动取默认值0,由于0比任何正整数都小,因此从14,5,0中选最大者和从14,5中选大者的结果是一样的。

12.输入两个整数,将它们按由大到小的顺序输出。要求使用变量的引用。

【解】 可以编写出以下程序:

#include<iostream>

using namespace std

int main( )

{ void change(int &,int &)

int a,b

cin>>a>>b

if(a<b) change(a,b)//如果a<b,使a和b的值互换

cout<<"max="<<a<<" min="<<b<<endl

return 0

}

void change(int &r1,int &r2) //函数的作用是使r1与r2互换

{ int temp

temp=r1

r1=r2

r2=temp

}

运行情况如下:

12 67↙

max=67 min=12

13.对3个变量按由小到大顺序排序,要求使用变量的引用。

【解】 可以编写出以下程序:

#include <iostream>

using namespace std

int main( )

{void sort(int &,int &,int &)

int a,b,c,a1,b1,c1

cout<<" Please enter 3 integers:"

cin>>a>>b>>c

a1=ab1=bc1=c

sort(a1,b1,c1)

cout<<a<<" "<<b<<" "<<c<<" in sorted order is "

cout<<a1<<" "<<b1<<" "<<c1<<endl

return 0

}

void sort(int &i,int &j,int &k)

{ void change(int &,int &)

if (i>j) change(i, j)

if (i>k) change(i, k)

if (j>k) change(j, k)

}

void change(int &x,int &y)

{ int temp

temp=x

x=y

y=temp

}

运行情况如下:

Please enter 3 integers:23 67 -55↙

23 67 –55 in sorted order is –55 23 67

这个程序很容易理解,不易出错。由于在调用sort函数时虚实结合使形参i,j,k成为实参a1,b1,c1的引用(别名),因此通过调用函数sort(a1,b1,c1)既实现了对i,j,k排序,也就同时实现了对a1,b1,c1排序。同样,执行change(i,j)函数,可以实现对实参i和j的互换。

14.编一程序,将两个字符串连接起来,结果取代第一个字符串。要求用string方法。

【解】 可以编写出以下程序:

#include <iostream>

#include <string> //程序中若使用字符串变量,必须包含头文件string

using namespace std

int main( )

{ string s1= " week ",s2= " end "

cout <<" s1= " <<s1 <<endl

cout <<"s2=" <<s2 <<endl

s1=s1+s2

cout<<" The new string is: "<<s1<<endl

return 0

}

运行情况如下:

s1=week

s2=end

The new string is: weekend

15.输入一个字符串,把其中的字符按逆序输出。如输入LIGHT,输出THGIL。要求用string方法。

【解】 可以编写出以下程序:

#include <iostream>

#include <string>

using namespace std

int main( )

{ string str   //定义字符串变量str

int i,n

char temp //定义字符变量temp

cout<<" please input a string: "

cin>>str //输入一个字符串赋给字符串变量str

n=str.size( ) //测量str的长度n

for(i=0i<n/2i++) //使str中的字符对称互换

{temp=str[i]str[i]=str[n-i-1]str[n-i-1]=temp}

cout <<str <<endl

return 0

}

运行情况如下:

please input a string:

LIGHT↙

THGIL

注意:输入的字符串中不能含有空格。

16.有5个字符串,要求将它们按由小到大的顺序排列,用string方法。

【解】 可以编写出以下程序:

#include <iostream>

#include <string>

using namespace std

int main( )

{ int i

string str[5]={" BASIC"," C"," FORTRAN"," C++","PASCAL"}

void sort(string [ ])

sort(str)//对字符串排序

cout<<" the sorted strings : "<<endl

for(i=0i<5i++)

cout<<str[i]<<" " //按已排好的顺序输出字符串

cout<<endl

return 0

}

void sort(string s[ ])

{int i, j

string t

for (j=0j<5j++)

for(i=0i<5-ji++)

if (s[i]>s[i+1])

{t=s[i]s[i]=s[i+1]s[i+1]=t}

}

运行结果如下:

the sorted strings :

BASIC C C++ FORTRAN PASCAL

17.编一个程序,用同一个函数名对n个数据进行从小到大排序,数据类型可以是整型、单精度型、双精度型。用重载函数实现。

【解】 可以编写出以下两个程序:

(1)建立3个函数,分别用于处理整型、单精度型、双精度型数据的排序,在3个函数中都采用选择法排序方法。

#include <iostream>

#include <string>

using namespace std

int main( )

{

long a[5]={10100,-123567, 1198783,-165654, 3456}

int b[5]={1,9,0,23,-45}

float c[5]={2.4, 7.6, 5.5, 6.6, -2.3 }

void sort(long [ ])

void sort(int [ ])

void sort(float [ ])

sort(a)

sort(b)

sort(c)

return 0

}

void sort(long a[ ])

{int i, j

long t

for (j=0j<5j++)

for(i=0i<5-ji++)

if (a[i]>a[i+1])

{t=a[i]a[i]=a[i+1]a[i+1]=t}

cout<<" the sorted numbers : "<<endl

for(i=0i<5i++)

cout<<a[i]<<" "

cout<<endl<<endl

}

void sort(int a[ ])

{int i, j, t

for (j=0j<5j++)

for(i=0i<5-ji++)

if (a[i]>a[i+1])

{t=a[i]a[i]=a[i+1]a[i+1]=t}

cout<<" the sorted numbers : "<<endl

for(i=0i<5i++)

cout<<a[i]<<" "

cout<<endl<<endl

}

void sort(float a[ ])

{int i, j

float t

for (j=0j<5j++)

for(i=0i<5-ji++)

if (a[i]>a[i+1])

{t=a[i]a[i]=a[i+1]a[i+1]=t}

cout<<" the sorted numbers : "<<endl

for(i=0i<5i++)

cout<<a[i]<<" "

cout<<endl<<endl

}

运行结果如下:

the sorted numbers :

-123567 -165654 10100 3456 1198783 (长整型数据排序)

the sorted numbers :(整型数据排序)

-45 0 1 9 23

the sorted numbers :

-2.3 2.4 5.5 6.6 7.6 (单精度型数据排序)

(2)在第1种方法中,3个函数的函数体基本上是相同的,都是采用选择法排序,在下面的程序中,3个函数的函数体不全相同,前两个函数采用选择法排序,最后一个函数采用起泡法排序。

#include <iostream>

#include <string>

using namespace std

int main( )

{ long a[5]= {10100,-123567, 1198783,-165654, 3456}

int b[5]={1,9,0,23,-45}

float c[5]={2.4, 7.6, 5.5, 6.6, -2.3 }

void sort(int [ ])

void sort(float [ ])

void sort(long [ ])

sort(a)//对长整型数据排序

sort(b)//对整型数据排序

sort(c)//对单精度型数据排序

return 0

}

void sort(long a[ ]) //对长整型数据用选择法排序的函数

{int i,j,min

long t

for(i=0i<5i++)

{min=i

for (j=i+1j<5j++)

if(a[min]>a[j]) min=j

{t=a[i]a[i]=a[min] a[min]=t}

cout<<" the sorted numbers : "<<endl

for(i=0i<5i++)

cout<<a[i]<<" "

cout<<endl<<endl

}

void sort(int a[ ])//对整型数据用选择法排序的函数

{int i, j, t

for (j=0j<5j++)

for(i=0i<5-ji++)

if (a[i]>a[i+1])

{t=a[i]a[i]=a[i+1]a[i+1]=t}

cout<<" the sorted numbers : "<<endl

for(i=0i<5i++)

cout<<a[i]<<" "

cout<<endl<<endl

}

void sort(float a[ ]) //对单精度型数据用起泡法排序的函数

{int i, j

float t

for (j=0j<5j++)

for(i=0i<5-ji++)

if (a[i]>a[i+1])

{t=a[i]a[i]=a[i+1]a[i+1]=t}

cout<<" the sorted numbers : "<<endl

for(i=0i<5i++)

cout<<a[i]<<" "

cout<<endl<<endl

}

运行结果如下:

the sorted numbers :

-123567 -165654 10100 3456 1198783 (长整型数据排序结果)

the sorted numbers : (整型数据排序结果)

-45 0 1 9 23

the sorted numbers :

-2.3 2.4 5.5 6.6 7.6(单精度型数据排序结果)

对比两种方法,可以看到,并不要求重载函数的函数体相同,在本例中,采用不同的排序方法,结果是相同的。从理论上说,重载的函数可以用来实现完全不同的功能,但是应该注意:同一个函数名最好用来实现相近的功能,而不要用来实现完全不相干的功能,以方便用户理解和使用。

18.对第17题改用函数模板实现。并与17题程序进行对比分析。

#include <iostream>

#include <string>

using namespace std

template <typename T >

void sort(T a[ ])//函数模板,采用选择法排序

{int i, j, min

T t

for(i=0i<5i++)

{min=i

for (j=i+1j<5j++)

if(a[min]>a[j]) min=j

t=a[i]a[i]=a[min]a[min]=t

}

cout<<" the sorted numbers : "<<endl

for(i=0i<5i++)

cout<<a[i]<<" "

cout<<endl<<endl

}

int main( )

{ long a[5]={10100,-123567, 1198783,-165654, 3456}

int b[5]={1,9,0,23,-45}

float c[5]={2.4, 7.6, 5.5, 6.6, -2.3 }

sort(a)

sort(b)

sort(c)

return 0

}

运行结果如下:

the sorted numbers :

-123567 -165654 10100 3456 1198783(长整型数据排序)

the sorted numbers : (整型数据排序)

-45 0 1 9 23

the sorted numbers :

-2.3 2.4 5.5 6.6 7.6 (单精度型数据排序)

对比第17题和18题,可以看到,如果重载函数的函数体基本相同的话,用函数模板显然更方便,可以压缩程序篇幅,使用方便。


欢迎分享,转载请注明来源:内存溢出

原文地址:https://54852.com/yw/7740746.html

(0)
打赏 微信扫一扫微信扫一扫 支付宝扫一扫支付宝扫一扫
上一篇 2023-04-09
下一篇2023-04-09

发表评论

登录后才能评论

评论列表(0条)

    保存