版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、习题4及其解答4.1 选择题1以下对一维数组 a 的正确定义是( c )。(a) int n = 5, an; (b) int a(5);(c) const int n = 5; int an; (d) int n ; cout << n << endl ; int an;2下列数组定义语句中,不合法的是( a )。(a) int a3 = 0, 1, 2, 3 ; (b) int a = 0, 1, 2 ;(c) int a3 = 0, 1, 2 ; (d) int a3 = 0 ;3已知 int a10 = 0, 1, 2, 3, 4, 5, 6, 7, 8, 9
2、, *p = a ;则不能表示数组 a 中元素的式子是( c )。(a) *a (b) *p (c) a(d) a p-a 4已知 int a = 0, 2, 4, 6, 8, 10 , *p = a ; 值不等于0的表达式是( b,d )。(a) *( p + ) (b) *( + p ) (c) *( p - )(d) *( - p )5以下不能对二维数组a进行正确初始化的语句是( c )。(a) int a23 = 0 ;(b) int a3 = 0, 1 , 0 ;(c) int a23 = 0, 1 , 2, 3 , 4, 5 ;(d) int a3 = 0, 1, 2, 3, 4,
3、 5 ;6已知int a3 = 0, 1 , 2, 3, 4 , 5, 6 , 7 ;则 a21的值是( c )。(a) 0 (b) 2(c) 6(d) 77已知int a33 = 1, 2, 3, 4, 5, 6, 7, 8, 9 ; 则不能表示数组元素a21的地址是( b )。(a) &a21 (b) *( a2 + 1 )(c) a2 + 1 (d) *( a+2 ) + 18已知char *a = "fortran ", " basic", "pascal ", "java", "c+&q
4、uot; ; 则 cout << a3;的显示结果是( c )。(a) t(b) 一个地址值(c) java (d) javac+9若用数组名作为调用函数的实参,则传递给形参的是( a )。(a) 数组存贮首地址(b) 数组的第一个元素值(c) 数组中全部元素的值(d) 数组元素的个数10下列描述中,错误的是( c )。(a) 输出字符指针就是输出字符串(b) 输出字符指针的间接引用就是输出单个字符(c) 所有字符相同的两个字符串常量相等(d) 两个数组名的比较是地址的比较11设char *s1,*s2;分别指向两个字符串。判断字符串s1和s2是否相等的表达式为( d )。(a)
5、s1 = s2(b) s1 = s2(c) strcpy( s1, s2 ) = 0(d) strcmp( s1, s2 ) = 013设char *s1,*s2;分别指向两个字符串。判断字符串s1是否大于字符串s2表达式为( c )。(a) s1 > s2(b) strcmp( s1, s2 ) = 0(c) strcmp( s1, s2 ) > 0(d) strcmp( s2, s1 ) > 04.2 阅读下列程序,写出执行结果1#include <iostream.h>void main() int i, conut=0, sum=0 ; float ave
6、rage ; int a = 1, 2, 3, 4, 5, 6, 7, 8, 9, 10 ; for( i=0; i<10; i+ ) if( ai % 2 = 0 ) continue ; sum += a i ; conut + ; average = sum / conut ; cout << "conut = " << conut << 't' << "average = " << average << endl ;答案: conut = 5 avera
7、ge = 52#include <iostream.h>void main() int a9 = 1, 2, 3, 4, 5, 6, 7, 8, 9 ; int *p = a , sum = 0 ; for( ; p<a+9; p+ ) if( *p % 2 = 0 ) sum += *p ; cout << "sum = " << sum << endl ;答案: sum = 203const int n = 5 ;#include <iostream.h>#include <iomanip.h>
8、;void main() int ann= 0 , i, j, k ; for( k=1 , i=0 ; i<n ; i+ ) for( j=i; j>= 0; j- , k+ ) aji - j = k ; for( i=0 ; i<n ; i+ ) for( j=0; j<n ; j+ ) cout << setw( 3 ) << aij ; cout << endl ; 答案: 1 3 6 10 15 2 5 9 14 0 4 8 13 0 0 7 12 0 0 0 11 0 0 0 0 4int f(int ,int);#in
9、clude <iostream.h>void main() int a = -1, 3, 5, -7, 9, -11 ; cout << f( a, 6 ) << endl ;int f( int a, int size ) int i, t=1 ; for( i=0 ; i<size; i + ) if( ai>0 ) t *= ai ; return t;答案: 1355int f( int 3, int, int ) ;#include <iostream.h>void main() int a3 = 0, 1, 2, 3, 4
10、, 5, 6, 7, 8 ; cout << f( a, 3, 3 ) << endl ;int f( int a3, int row, int col ) int i, j, t=1 ; for( i=0; i<row; i + ) for( j=0; j<col; j+ ) aij + ; if( i = j ) t *= aij ; return t ;答案: 456#include <iostream.h> void test1(int *a1) a1=new int(5); cout<<”*a1=”<<*a1&l
11、t;<endl; void test2(int *&a2) a2=new int(5); cout<<”*a2=”<<*a2<<endl;void main() int *p=new int(1); test1(p); cout<<”test1:*p1=”<<*p<<endl; test2(p); cout<<” test2:*p2=”<<*p<<endl;答案:*a1=5test1:*p1=1*a2=5Test2:*p2=57#include <iostream.h
12、>void main() char s = "abccda" ; int i ; char c ; for( i = 1 ; ( c=si ) != '0' i + ) switch( c ) case 'a' : cout << '%' ; continue ; case 'b' : cout << '$' ; break ; case 'c' : cout << '*' ; break ; case 'd
13、9; : continue ; cout << '#' << endl ; 答案: $# *# *# %continue对switch无效,如果这个switch是在一个循环中,switch中出现的continue其实是对这个循环做控制的,也就是说如果switch是在for或者while的循环中,那么continue可以在switch中出现,否则不行8#include <iostream.h>void main() char *str = "c+", "basic", "pascal"
14、 ; char *p ; int i ; p = str ; for( i=0 ; i<3 ; i+ ) cout << *( p+i ) << endl ;答案: c+ basic pascal9#include <iostream.h>void main() char s1 = "Fortran" , s2 = "Foxpro" ; char *p , *q ; p = s1 ; q = s2 ; while( *p && *q ) if ( *p = *q ) cout << *
15、p ; p + ; q + ; cout << endl ;答案: For10#include <string.h>#include <iostream.h>void main() char str10 = "vb", "pascal", "c+" , s10 ; strcpy( s , ( strcmp( str0 , str1 ) < 0 ? str0 : str1 ) ) ; if( strcmp( str2, s ) < 0 ) strcpy( s, str2 ) ; cout
16、<< s << endl ;答案: C+4.3 编程题1已知求成绩的平均值和均方差公式:,, 其中n为学生人数,s为第i个学生成绩。求某班学生的平均成绩和均方差。解答:#include <iostream.h>#include <math.h>void main() double s = 76, 85, 54, 77, 93, 83, 90, 67, 81, 65 ; double sum1=0,sum2=0,ave,dev; int n, i; n = sizeof( s )/sizeof( double ); /求数组元素的个数 for( i
17、=0; i<n; i+ ) sum1 += si; ave = sum1/n; for( i=0; i<n; i+ ) sum2 += pow( si-ave, 2 ); dev = sqrt( sum2/n ); cout << "rve=" << ave << 't' << "dev=" << dev << endl; 2用随机函数产生10个互不相同的两位整数存放到一维数组中,并输出其中的素数。解答:#include <iostream.h>
18、;#include <stdlib.h>#include <time.h>#include <math.h>void main() int a10,i,j; long m; srand( time(0) ); for( i=0; i<10; i+ ) l:ai = rand(); if ( ai<10 | ai>=100 ) goto l; for( j=0; j<i; j+ ) if( ai=aj ) goto l; for( i=0; i<10; i+ ) cout << ai << " &
19、quot; cout << endl; for( i=0; i<10; i+ ) double m=sqrt( ai ); for( j=2; j<=m; j+) if( ai % j = 0 )break; if( j>m ) cout << ai << " " cout << "是素数!" << endl; 3将一组数据从大到小排列后输出,要求显示每个元素及它们在原数组中的下标。解答:#include <iostream.h>void main() int a
20、= 38, 6, 29, 1, 25, 20, 6, 32, 78, 10 ; int index10; int i,j,temp; for( i=0; i<10; i+ ) indexi = i; for( i=0; i<=8; i+ ) for( j=i+1; j<=9; j+ ) if( ai < aj ) temp = ai; ai = aj; aj = temp; temp = indexi; indexi = indexj; indexj = temp; for( i=0; i<10; i+ ) cout << ai <<
21、39;t' << indexi << endl;4从键盘上输入一个正整数,判别它是否为回文数。所谓回文数是指正读和反读都一样的数。例如,123321是回文数。解答:#include <iostream.h>void main() int b10,i,k,f; long num,n; cout << "num=" cin >> num; k = 0; n = num; do bk = n % 10; k = k+1; n = n/10; while( n != 0); f=1; for( i=0; i<
22、=( k-1 )/2; i+ ) if( bi != b k 1 - i ) f = 0; if( f ) cout << num << "是回文数!" << endl; else cout << num << "不是回文数!" << endl;5把两个已升序的整型数组合并为一个升序数组。设计好你的算法,得到较高的运行效率。解答:#include <iostream.h>void main() int a4 = 1, 2, 5, 7 ; int b8 = 3, 4, 8,
23、 8, 9, 10, 11, 12 ; int c12,i,j,k; i = j = k = 0; while( i<4 && j<8 ) if( ai > bj ) ck = bj; k+; j+; else ck = ai; k+; i+; while( i<4 ) ck = ai; i+; k+; while( j<8 ) ck = bj; k+; j+; for( i=0; i<k; i+ ) cout << ci << " " cout << endl;6. 输入一个星期几号,
24、输出相应的英文单词。要求使用指针数组实现。解答:#include <iostream.h>void main() char *weekday7 = "sunday", "monday", "tuesday", "wednesday", "thursday", "friday", "saturday" ; int d; cout << "please input week day: " cin >> d
25、; if( d>=0 && d<=6 )cout << d << "-" << *( weekday + d ) <<endl; else cout << "input error!" << endl;7编写函数:(1)在一个数组中形成如以下的n阶矩阵: ,(2)去掉靠边元素,生成新的n-2阶矩阵;(3)求矩阵主对角线下元素之和;(4)以方阵形式输出数组。由main函数调用以上函数进行测试。解答:#include <iostream.h>voi
26、d create( int *&app, int n );void del( int *&app, int *&bpp, int n );int maindiagonal( int *&app, int n );void output( int *&app, int );void main() int *ap = NULL, *bp = NULL, n; cout << "输入矩阵的阶:" cin >> n; create( ap,n ); cout << "n形成矩阵:n" o
27、utput( ap, n ); cout << "去掉靠边元素生成的矩阵:n" del( ap,bp,n ); output( bp,n-2 ); cout << "主对角线元素之和:" << maindiagonal( ap, n ) <<endl;/形成n阶矩阵函数void create( int * &app, int n ) app = new int n*n ; int i,j,k = 0; for( i=0; i<n; i+ ) for( j=0; j<n; j+ ) if(
28、 i<=j ) appk = 1; else appk = i-j+1; k+; /去掉靠边元素生成n-2阶矩阵函数void del( int *&app, int *&bpp, int n ) int i,j,k = 0; bpp = new int (n-2)*(n-2) ; for ( i=0; i<n; i+ ) for( j=0; j<n; j+ ) if ( i && j && i<n-1 && j <n-1 ) bppk=app i*n+j ; k+; /求主对角线元素之和函数int m
29、aindiagonal( int *&app, int n ) int i,j,k = 0,sum = 0; for ( i=0; i<n; i+ ) for( j=0; j<n; j+ ) if( i=j ) sum += app i*n+j ; return sum;/以方阵的形式输出数组函数void output( int *&app, int n ) int i,j; for ( i=0; i<n ; i+ ) for( j=0; j<n; j+ ) cout << app i*n+j << 't' cou
30、t<<endl; cout<<endl;8设某一城市三个百货公司某个季度销售电视机的情况和价格由如下表格表示。编写程序,每个表格数据以数组存放,求各个百货公司的电视机营业额。 牌号 公司康佳TCL牌号价格康佳3500TCL3300长虹3800长虹第一百货公司300250150第二百货公司200240200第三百货公司280210180解答:#include <iostream.h>void main() long s3 = 300, 250, 150 , 200, 240, 200, 280, 210, 180 ; long p = 3500, 3300,
31、3800 ; int i,j; double sum; for( i=0; i<3; i+ ) sum=0; for( j=0; j<3; j+) sum += sij * pj; cout << "第" << i+1 << "百货公司的电视机营业额: " << sum << endl; 9设计函数求一整型数组的最小元素及其下标。在主函数中定义和初始化该整型数组,调用该函数,并显示最小元素值和下标值。解答:#include <iostream.h>int fmin(int
32、 , int);void main() int a = 73, 85, 62, 95, 77, 56, 81, 66, 90, 80 ; int index; index = fmin( a, sizeof(a)/sizeof(int) ); cout << "The minnum number is : " << aindex << endl; cout << "The index is : " << index << endl;int fmin( int a, int size
33、) int i,min = a0, index = 0; for( i=0; i<size; i+ ) if( ai<min ) min = ai; index = i; ; return index;10假设有从小到大排列的一组数据存放在一个数组中,在主函数中键入一个在该数组的最小值和最大值之间的数,并调用一函数把键入的数插入到原有的数组中,保持从小到大的顺序,并把最大数挤出。要求在主函数中输出改变后的数组。解答:#include <iostream.h>void insert( int a,int,int );void main() int a = 10, 12,
34、23, 25, 48, 48, 53, 58, 60, 78 ; int x,n,i; cout << "please input insert data: " cin >> x; n = sizeof(a)/sizeof(int); insert( a, n, x ); for( i=0; i<n; i+ ) cout << ai << " " cout << endl;void insert( int a,int n,int x ) int i,p,j; if ( x<an-1
35、) for( i=1; i<n; i+ ) if( x<ai ) p=i; break; for( j=n-1; j>=p; j- ) aj+1 = aj; ap = x; 11编写程序,按照指定长度生成动态数组,用随机数对数组元素赋值,然后逆置该数组元素。输出逆置前后的数组元素序列。解答:#include <iostream.h>#include <stdlib.h>#include <time.h>void main() int *p,n,i,t; cout << "请输入数组长度:" cin >&
36、gt; n; / 产生动态数组 p = new int n; srand( time(0) ); for( i=0; i<n; i+ ) *( p+i ) = rand(); / 输出动态数组 cout << endl; cout << "动态数组:" for( i=0; i<n; i+ ) if (i % 5 = 0) cout << endl; / 控制一行输出5个数据 cout << "array" << i << "=" << *(
37、p+i) << " " cout << endl; / 对数组逆序排列 for ( i=0; i<n/2; i+ ) t = *(p+i); *( p+i ) = *( p+n-i-1 ); *( p+n-i-1 )=t; / 输出逆序数组 cout << endl; cout << "逆序数组:" for( i=0; i<n; i+ ) if ( i % 5 = 0 ) cout << endl; cout << "array" << i
38、 << "=" << *(p+i) << " " cout << endl; 12把一个字符串插入到另一个字符串中指定位置。解答:#include <iostream.h>void main() int p, i, j, k; char s140, s240, s380; cout << "s1=" cin >> s1; cout << "s2=" cin >> s2; cout << "
39、;input insert position:" cin >> p; for( i=0; i<p; i+ ) s3i = s1i; for( j=0; s2j != '0' j+ ) s3i+j = s2j; for( k=p; s1k != '0' k+ ) s3j+k = s1k; s3j+k = '0' cout << "s3=" << s3 << endl;13把某班学生的姓名和学号分别存放到两个数组中,从键盘上输入某一学生学号,查找该学生是否在该班,若找到该学生,则显示出相应的姓名。解答:#include <iostream.h>void main() char name520 = "li ming", "zhang qing", "liu xiao ping", "wang ying", "lu pei&
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 二零二五年度农业现代化农机租赁服务合同3篇
- 二零二五年度股东合作打造智能物流网络合同3篇
- 二零二五年度环保材料墙绘施工合同3篇
- 2025年度新型广告字生产、安装及售后服务合同3篇
- 二零二五年度老年健身器材租赁合同2篇
- 2025年度租赁车辆环保排放检测与治理合同3篇
- 2025年度公司定制婚礼用花采购服务合同2篇
- 二零二五年度人工智能医疗设备研发团队劳动合同终止补偿协议2篇
- 2025年度养老院入住与医疗费用结算合同2篇
- 二零二五年度口腔诊所与口腔材料供应商战略合作合同3篇
- 2024江苏省铁路集团限公司春季招聘24人高频考题难、易错点模拟试题(共500题)附带答案详解
- 2024智能变电站新一代集控站设备监控系统技术规范部分
- 企业反恐专项经费保障制度
- 电梯工程师在电梯设计中的工作内容
- 《概率论与数理统计基础》全套教学课件
- 2024国家开放大学电大本科《液压气动技术》期末试题及答案
- 肥猪销售合同模板
- 餐饮顾问合作协议
- 新教材牛津译林版高中英语必修第二册全册各单元重点语法精讲
- 两课 说课 单相桥式整流电路分析(获奖)
- 中国移动《下一代全光骨干传送网白皮书》
评论
0/150
提交评论