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 和

6.7完数

main()

#include M 1000/*定义寻找范围*/

main()

{

int k0,k1,k2,k3,k4,k5,k6,k7,k8,k9

int i,j,n,s

for(j=2j<=Mj++)

{

n=0

s=j

for(i=1i<ji++)

{

if((j%i)==0)

{

if((j%i)==0)

{

n++

s=s-i

switch(n)/*将每个因子赋给k0,k1…k9*/

{

case 1:

k0=i

break

case 2:

k1=i

break

case 3:

k2=i

break

case 4:

k3=i

break

case 5:

k4=i

break

case 6:

k5=i

break

case 7:

k6=i

break

case 8:

k7=i

break

case 9:

k8=i

break

case 10:

k9=i

break

}

}

}

if(s==0)

{

printf("%d是一个‘完数’,它的因子是",j)

if(n>1)

printf("%d,%d",k0,k1)

if(n>2)

printf(",%d",k2)

if(n>3)

printf(",%d",k3)

if(n>4)

printf(",%d",k4)

if(n>5)

printf(",%d",k5)

if(n>6)

printf(",%d",k6)

if(n>7)

printf(",%d",k7)

if(n>8)

printf(",%d",k8)

if(n>9)

printf(",%d",k9)

printf("\n")

}

}

方法二:此题用数组方法更为简单.

main()

{

static int k[10]

int i,j,n,s

for(j=2j<=1000j++)

{

n=-1

s=j

for(i=1i<ji++)

{

if((j%i)==0)

{

n++

s=s-i

k[n]=i/*将每个因子赋给k0,k1...k9*/

}

}

if(s==0)

{

printf("%d是一个完数,它的因子是:",j)

for(i=0i<ni++)

printf("%d,",k[i])

printf("%d\n",k[n])

}

}

5.8 有一个分数序列:2/1,3/2,5/3,8/5……求出这个数列的前20项之和.

解: main()

{

int n,t,number=20

float a=2,b=1,s=0

for(n=1n<=numbern++)

{

s=s+a/b

t=a,a=a+b,b=t

}

printf("总和=%9.6f\n",s)

}

6.9球反d问题

main()

{

float sn=100.0,hn=sn/2

int n

for(n=2n<=10n++)

{

sn=sn+2*hn/*第n次落地时共经过的米数*/

hn=hn/2/*第n次反跳高度*/

}

printf("第10次落地时共经过%f米 \n",sn)

printf("第10次反d%f米.\n",hn)

}

6.10猴子吃桃

main()

{

int day,x1,x2

day=9

x2=1

while(day>0)

{

x1=(x2+1)*2

x2=x1

day--

}

printf("桃子总数=%d\n",x1)

}

6.14打印图案

main()

{

int i,j,k

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

{

for(j=0j<=2-1j++)

printf(" ")

for(k=0k<=2*ik++)

printf("*")

printf("\n")

}

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

{

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

printf(" ")

for(k=0k<=4-2*ik++)

printf("*")

printf("\n")

}

6.15乒乓比赛

main()

{

char i,j,k/*i是a是对手j是b是对手k是c的对手*/

for(i='x'i<='z'i++)

for(j='x'j<='z'j++)

{

if(i!=j)

for(k='x'k<='z'k++)

{

if(i!=k&&j!=k)

{if(i!='x' &&k!='x' &&k! ='z')

printf("顺序为:\na-%c\tb--%c\tc--%c\n",i,j,k)

}

}

}

}

7.1用筛选法求100之内的素数.

/*用筛选法求100之内的素数*/

#include<math.h>

#define N 101

main()

{int i,j,line,a[N]

for(i=2i<Ni++) a[i]=i

for(i=2i<sqrl(N)i++)

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

{if(a[i]!=0 &&a[j]!=0)

if(a[j]%a[i]==0)

a[j]=0

printf("\n")

for(i=2,line=0i<Ni++)

{ if(a[i]!=0)

{printf("%5d",a[i])

line++

if(line==10)

{printf("\n")

line=0}

}

}

7.2用选择法对10个数排序.

/*选择法排序.*/

#define N 10

main()

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

/*输入数据*/

printf("请输入十个数:\n")

for (i=0i<Ni++)

{ printf("a[%d]=",i)

scanf("%d",&a[i])

}

printf("\n")

for(i=0i<Ni++)

printf("%5d",a[i])

printf("\n")

/*排序*/

for (i=0i<N-1i++)

{ min=i

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

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

temp=a[i]

a[i]=a[min]

a[min]=temp

}

/*输出*/

printf("\n排序结果如下:\n")

for(i=0i<Ni++)

printf("%5d",a[i])

}

7.3对角线和:

/*计算矩阵对角线元素之和*/

main()

{

float a[3][3],sum=0

int i,j

printf("请输入矩阵元素:\n")

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

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

scanf("%f",&a[i][j])

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

sum=sum+a[i][i]

printf("对角元素之和=6.2f",sum)

}

7.4插入数据到数组

/*插入数据到数组*/

main()

{int a[11]={1,4,6,9,13,16,19,28,40,100}

int temp1,temp2,number,end,i,j

printf("初始数组如下:")

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

printf("%5d",a[i])

printf("\n")

printf("输入插入数据:")

scanf("%d",&number)

end=a[9]

if(number>end)

a[10]=number

else

{for(i=0i<10i++)

{ if(a[i]>number)

{temp1=a[i]

a[i]=number

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

{temp2=a[j]

a[j]=temp1

temp1=temp2

}

break

}

}

}

for(i=0j<11i++)

printf("a%6d",a[i])

}

7.5将一个数组逆序存放。

/*数组逆序存放*/

#define N 5

main()

{ int a[N]={8,6,5,4,1},i,temp

printf("\n 初始数组:\n")

for(i=0i<Ni++)

printf("%4d",a[i])

for(i=0i<N/2i++)

{ temp=a[i]

a[i]=a[N-i-1]

a[N-i-1]=temp

}

printf("\n 交换后的数组:\n")

for(i=0i<Ni++)

printf("%4d",a[i])

}

7.6杨辉三角

/*打印杨辉三角形*/

#define N 11

main()

{ int i,j,a[N][N]

for(i=1i<Ni++)

{a[i][i]=1

a[i][1]=1

}

for(i=3i<Ni++)

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

a[i][j]=a[i01][j-1]+a[i-1][j]

for(i=1i<Ni++)

{ for(j=1j<=ij++)

printf("%6d",a[i][j]

printf("\n")

}

printf("\n")

}

7.8鞍点

/*查找鞍点*/

#define N 10

#define M 10

main()

{ int i,j,k,m,n,flag1,flag2,a[N][M],max,maxi,maxj

printf("\n输入行数n:")

scanf("%d",&n)

printf("\n输入列数m:")

scanf("%d",&m)

for(i=0i<ni++)

{ printf("第%d行?\n",i)

for(j=0j<m,j++)

scanf("%d",&a[i][j]

}

for(i=0i<ni++)

{ for(j=0j<mj++)

printf("%5d",a[i][j])

pritf("\n")

}

flag2=0

for(i=0i<ni++)

{ max=a[i][0]

for(j=0j<mj++)

if(a[i][j]>max)

{ max=a[i][j]

maxj=j

}

for (k=0,flag1=1k<n &&flag1k++)

if(max>a[k][max])

flag1=0

if(flag1)

{ printf("\n第%d行,第%d列的%d是鞍点\n",i,maxj,max)

flag2=1

}

}

if(!flag2)

printf("\n 矩阵中无鞍点! \n")

}

7.9变量说明:top,bott:查找区间两端点的下标loca:查找成功与否的开关变量.

/*折半查找*/

#include<stdio.h>

#define N 15

main()

{ int i,j,number,top,bott,min,loca,a[N],flag

char c

printf("输入15个数(a[i]>[i-1])\n)

scanf("%d",&a[0])

i=1

while(i<N)

{ scanf("%d",&a[i])

if(a[i]>=a[i-1])

i++

esle

{printf("请重输入a[i]")

printf("必须大于%d\n",a[i-1])

}

}

printf("\n")

for(i=0i<Ni++)

printf("%4d",a[i])

printf("\n")

flag=1

while(flag)

{

printf("请输入查找数据:")

scanf("%d",&number)

loca=0

top=0

bott=N-1

if((number<a[0])||(number>a[N-1]))

loca=-1

while((loca==0)&&(top<=bott))

{ min=(bott+top)/2

if(number==a[min])

{ loca=min

printf("%d位于表中第%d个数\n",number,loca+1)

}

else if(number<a[min])

bott=min-1

else

top=min+1

}

if(loca==0||loca==-1)

printf("%d不在表中\n",number)

printf("是否继续查找?Y/N!\n")

c=getchar()

if(c=='N'||c=='n')

flag=0

}

}

7.10/*统计字符数*/

main()

{ int i,j,uppn,lown,dign,span,othn

char text[3][80]

uppn=lown=dign=span=othn=0

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

{ printf("\n请输入第%d行:\n",i)

gets(text[i])

for(j=0j<80 &&text[i][j]!='\0'j++)

{if(text[i][j]>='A' &&text[i][j]<='Z')

uppn+=1

else if(text[i][j]>='a' &&text[i][j]<='z')

lown+=1

else if(text[i][j]>='1' &&text[i][j]<='9')

dign+=1

else if(text[i][j]=' ')

span+=1

else

othn+=1

}

}

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

printf("%s=n",text[i])

printf("大写字母数:%d\n",uppn)

printf("小写字母数:%d\n",lown)

printf("数字个数:%d\n",dign)

printf("空格个数:%d\n",span)

printf("其它字符:%d\n",othn)

}

7.11/*打印图案*/

main()

{static char a[5]={'*','*','*','*','*'}

int i,j,k

char space=' '

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

{printf("\n")

for(j=1j<=3*ij++)

printf("%lc",space)

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

printf("%3c",a[k]

}

}

7.12/*译电文*/

#include<stdio.h>

main()

{int i,n

char ch[80],tran[80]

printf("请输入字符:")

gets(ch)

printf("\n密码是%c",ch)

i=0

while(ch[i]!='\0')

{if((ch[i]>='A')&&(ch[i]<='Z'))

tran[i]=26+64-ch[i]+1+64

else if((ch[i]>='a')&&(ch[i]<='z'))

tran[i]=26+96-ch[i]+1+96

else

tran[i]=ch[i]

i++

}

n=i

printf("\n原文是:")

for(i=0i<ni++)

putchar(tran[i])

}

7.13/*连接两个字符串(不用'stract')*/

main()

{

char s1[80],s2[40]

int i=0,j=0

printf("\n请输入字符串1:")

scanf("%s",s1)

printf("\n请输入字符串2:")

scanf("%s",s2)

while(s1[i]!='\0')

i++

while(s2[j]!='\0')

s1[i++]=s2[j++]

s1[i]='\0'

printf("\n连接后字符串为:%s",s1)

}

7.14/*字符串比较*/

#include<stdio.h>

main()

{int i,resu

char s1[100],s2[100]

printf("请输入字符串1:\n")

gets(s1)

printf("\n 请输入字符串2:\n")

gets(s2)

i=0

while((s1[i]==s2[i]) &&(s1[i]!='\0'))i++

if(s1[i]=='\0' &&s2[i]=='\0')resu=0

else

resu=s1[i]-s2[i]

printf(" %s与%s比较结果是%d",s1,s2,resu)

}

7.15/*字符串复制*/

#include<stdio.h>

main()

{

char from[80],to[80]

int i

printf("请输入字符串")

scanf("%s",from)

for(i=0i<=strlen(from)i++)

to[i]=from[i]

printf("复制字符串为:%s\n",to)

}

第八章 函数

8.1(最小公倍数=u*v/最大公约数.)

hcf(u,v)

int u,v

(int a,b,t,r

if(u>v)

{t=uu=vv=t}

a=ub=v

while((r=b%a)!=0)

{b=aa=r}

return(a)

}

lcd(u,v,h)

int u,v,h

{int u,v,h,l

scanf("%d,%d",&u,&v)

h=hcf(u,v)

printf("H.C.F=%d\n",h)

l=lcd(u,v,h)

printf("L.C.d=%d\n",l)

}

{return(u*v/h)}

main()

{int u,v,h,l

scanf("%d,%d",&u,&v)

h=hcf(u,v)

printf("H.C.F=%d\n",h)

l=lcd(u,v,h)

printf("L.C.D=%d\n",l)

}

8.2求方程根

#include<math.h>

float x1,x2,disc,p,q

greater_than_zero(a,b)

float a,b

{

x1=(-b+sqrt(disc))/(2*a)

x2=(-b-sqrt(disc))/(2*a)

}

equal_to_zero(a,b)

float a,b

{x1=x2=(-b)/(2*a)}

smaller_than_zero(a,b)

float a,b

{p=-b/(2*a)


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

原文地址: http://outofmemory.cn/yw/10890136.html

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

发表评论

登录后才能评论

评论列表(0条)

保存