收藏 分销(赏)

C语言程序设计形成性作业二.doc

上传人:人****来 文档编号:9755647 上传时间:2025-04-06 格式:DOC 页数:6 大小:52KB 下载积分:6 金币
下载 相关 举报
C语言程序设计形成性作业二.doc_第1页
第1页 / 共6页
C语言程序设计形成性作业二.doc_第2页
第2页 / 共6页


点击查看更多>>
资源描述
C语言程序设计形成性作业二 一、 选择题 1. 在下面的一维数组定义中,(C)语句有语法错误。 A.int a[]={1,2,3}; B.int a[10]={0}; C.int a[]; D.int a[5];n 2.在下面的二维数组定义中,(C)语句是正确的。 A.int a[5][]; B.int a[][5]; C.int a[][3]={{1,3,5},{2}}; D.int a[](10) 3.假定一个二维数组的定义语句为“int a[3][4]={{3,4},{2,8,6}};”,则元素a[1][2]的值为(C)。 A.2 B.4 C.6 D.8 4.假定一个二维数组的定义语句为“int a[3][4]={{3,4},{2,8,6}};”,则元素a[2][1]的值为(A)。 A.0 B.4 C.8 D.6 5.将两个字符串连接起来组成一个字符串时,选用(C)函数。 A.strlen() B.strcap() C.strcat() D.strcmp() 二、填空题 1.假定一维数组的定义为“char * a[8];”,则该数组所含元素的个数为_8_。 2.假定一维数组的定义为“char * a[8];”,则该数组所占存储空间的字节数为_32_。 3.假定二维数组的定义为“int a[3][5]”,则该数组所占存储空间的字节数为_60_。 4.假定二维数组的定义为“char a[M][N];”,则该数组所所含元素的个数为_ M*N _。 5.假定二维数组的定义为“double a[M][N];”,则每个数组元素的行下标取值范围在_0~M-1_之间。 6.假定二维数组的定义为“double a[M][N];”,则每个数组元素的列下标取值范围在_0~N-1_之间。 7.使用“typedef char BB[10][50];”语句定义_BB_为含有10行50列的二维字符数组类型。 8.存储字符’a’需要占用存储器的_1_个字节空间。 9.空字符串的长度为_0_。 10.存储一个空字符串需要占用_1_个字节。 11.字符串”a:\\xxk\\数据”的长度为_11_。 12.用于存储一个长度为n的字符串的字符数组的长度至少为_n+1_。 13.strcmp函数用于进行两个字符串之间的_比较_。 14.Strcpy函数用于把一个字符串_拷贝(复制)_另一个字符数组空间中。 15.一个二维字符数组a[10][20]能够存储_10_个字符串。 16.一个二维字符数组a[10][20]能够存储的每个字符串的长度至多为_19_. 三、写出下列每个程序运行后的输出结果 1. #include<stdio.h> void main() { int a[10]={12,39,26,41,55,63,72,40,83,95}; int i,i1=0,i2=0; for(i=0;i<10;i++) if(a[i]%2==1)i1++;else i2++; printf("%d %d\n",i1,i2); } 6 4 2. #include<stdio.h> #include<string.h> void main() { int i; char *a[5]={"student","worker","cadre","soldier","peasant"}; char *p1,*p2; p1=p2=a[0]; for(i=0;i<5;i++){ if(strcmp(a[i],p1)>0)p1=a[i]; if(strcmp(a[i],p2)<0)p2=a[i]; } printf("%s %s\n",p1,p2); } worker cadre 3. #include<stdio.h> int a[10]={4,5,6,15,20,13,12,7,8,9}; void main() { int i,s0,s1,s2; s0=s1=s2=0; for(i=0;i<10;i++){ switch(a[i]%3){ case 0:s0+=a[i];break; case 1:s1+=a[i];break; case 2:s2+=a[i];break; } } printf("%d %d %d\n",s0,s1,s2); } 42 24 33 4. #include<stdio.h> void main() { char a[]="abcdbfbgacd"; int i1=0,i2=0,i=0; while(a[i]){ if(a[i]=='a')i1++; if(a[i]=='b')i2++; i++; } printf("%d %d %d\n",i1,i2,i); } 2 3 11 5. #include<stdio.h> void main() { int a[3][4]={{1,2,7,8},{5,6,10,6},{9,12,3,4}}; int m=a[0][0]; int ii=0,jj=0; int i,j; for(i=0;i<3;i++) for(j=0;j<4;j++) if(a[i][j]>m){m=a[i][j];ii=i;jj=j;} printf("%d %d %d\n",ii,jj,a[ii][jj]); } 2 1 12 6. #include<stdio.h> void main() { int a,b; for(a=1,b=2;b<50;){ printf("%d %d ",a,b); a=a+b; b=a+b; } printf("\n"); } 1 2 3 5 8 13 21 34 四、写出下列每个函数的功能 1. #include<stdio.h> int SA(int a,int b){ if(a>b)return 1; else if(a==b)return 0; else return -1; } 比较两个整数a和b的大小,若a>b则返回1,若a==b则返回0,若a<b则返回-1。 2. #include<stdio.h> int SC(int a,int b,int c){ if(a>=b && a>=c)return a; if(b>=a && b>=c)return b; return c; } 求出a,b,c三个数中的最大值并返回。 3.double SF(double x,int n){ //n为大于等于0的整数 double p=1,s=1; for(i=1;i<=n;i++){ p*=x; s+=p/(i+1); } return s; } 计算1+x/2+x2/3+...+xn/(n+1)的值并返回。 4. #include<math.h> int SC(int x){ int a=(int)sqrt(x); int i=2; while(i<=a){ if(x%i==0)break; i++; } if(i<=0)return 0;else return 1; } 判断x是否为一个素数,若是则返回1,否则返回0。 5. #include<stdio.h> void trans(int x) { char a[10]; int i=0,rem; do{ rem=x%16; x=x/16; if(rem<10)a[i]=48+rem;//'0'字符的ASCII码为48 else a[i]=65+rem; //'A'字符的ASCII码为55 i++; }while(x!=0); while(i>0)printf("%c",a[--i]); printf("\n"); } 此函数用于把十进制整数x转换为十六进制数字串输出 五、根据下列每个题目要求编写程序 1.编写一个函数,函数头格式为“void fun4(char *a , int b[])”,分别求出由字符指针a所指向的字符串中包含的每种十进制数字出现的次数,把统计结果保存在数组b的相应元素。 void fun4(char* a, int b[]) { int i; for(i=0;i<10;i++) b[i]=0; //对b数组初始化 while(*a) { int j=*a-'0'; if(j>=0 && j<=9) b[j]++; a++; } } 2. 编写一个函数,函数头格式为“double Mean(double a[M][N] , int m , int n)”,要求返回二维数组a[m][n]中所有元素的平均值,假定在计算过程是采用变量v存放平均值。 double Mean(double a[M][N],int m,int n) { int i,j; double v=0.0; for(i=0; i<m; i++) for(j=0; j<n; j++) v+=a[i][j]; v/=m*n; return v; } 3. 编写一个递归函数“int FF(int a[] , int n)”,求出数组a中所有元素n个元素之积并返回。 int FF(int a[], int n) { if(n==1) return a[n-1]; else return a[n-1]*FF(a,n-1); } 4. 编写一个主函数,利用while循环,求出并显示满足不等式1+1/2+1/3+……+1/n>5的最小n值。 #include<stdio.h> void main() { int i=0; double s=0; //或int i=1; double s=1; while(s<5) s+=(double)1/++i; printf("n=%d\n",i); } 5. 编写一个主函数,求满足不等式22+42+……+n2<1000的最大n值,假定分别用i和s为取偶数值和累加值的变量,并限定使用do循环编程。 #include<stdio.h> void main() { int i=0; //用i作为依次取值偶数的变量 int s=0; //用s作为累加变量 do { i+=2; s+=i*i; }while(s<1000); printf("n=%d\n",i-2); } 6. 编写一个主函数,计算并输出n 的值,其中n值由键盘输入。 #include<stdio.h> void main() { int i; //用i作为计数(循环)变量 int s=0; //用s作为累加变量 int n; printf("输入一个自然数: "); scanf("%d",&n); for(i=1; i<=n; i++) s+=i*i; printf("s=%d\n",s); }
展开阅读全文

开通  VIP会员、SVIP会员  优惠大
下载10份以上建议开通VIP会员
下载20份以上建议开通SVIP会员


开通VIP      成为共赢上传

当前位置:首页 > 教育专区 > 远程教育/电大

移动网页_全站_页脚广告1

关于我们      便捷服务       自信AI       AI导航        抽奖活动

©2010-2025 宁波自信网络信息技术有限公司  版权所有

客服电话:4009-655-100  投诉/维权电话:18658249818

gongan.png浙公网安备33021202000488号   

icp.png浙ICP备2021020529号-1  |  浙B2-20240490  

关注我们 :微信公众号    抖音    微博    LOFTER 

客服