
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题,可以看到,如果重载函数的函数体基本相同的话,用函数模板显然更方便,可以压缩程序篇幅,使用方便。
欢迎分享,转载请注明来源:内存溢出
微信扫一扫
支付宝扫一扫
评论列表(0条)