二级C语言-387
(总分:100.00,做题时间:90分钟)
一、程序填空题(总题数:1,分数:30.00)
1.请补充函数proc(),函数proc()的功能是求7的阶乘。
注意:部分源程序给出如下。
请勿改动main()函数和其他函数中的任何内容,仅在函数proc()的横线上填入所编写的若干表达式或语句。
试题程序:
#include<stdio.h>
long proc(int n)
{
if( 1)
return(n*proc( 2);
else if( 3)
return 1;
}
void main()
{
int k=7;
printf("%d!=%ld/n",k,proc(k));
}

(分数:30.00)
解析:n>1 n-1 n==1[解析] 本题求阶乘是由函数递归调用来实现的。阶乘公武为N!=N*(N-1)!,因此第一处填“n>1”;由递归的性质可知第二处填“n-1”;直到N=1时结束递归调用,因此第三处填“n==1”。
二、程序改错题(总题数:1,分数:30.00)
2.下列给定的程序中,函数proc()的功能是:用选择法对数组中的m个元素按从小到大的顺序进行排序。
例如,排序前的数据为:11 32 -5 2 14
则排序后的数据为:-5 2 11 14 32
请修改程序中的错误,使它能得到正确结果。
注意:不要改动main()函数,不得增行或删行,也不得更改程序的结构。
试题程序:
#include<stdio.h>
#define M 20
void proc(int a[],int n)
{
int i,j,t,p;
//****found****
for(j=0;j<n-1;j++);
{
p=j;
for(i=j;i<n;i++)
if(a[i]<a[p])
p=i;
t=a[p];
a[p]=a[j];
//****found****
a[p]=t;
}
}
void main()
{
int arr[M]={11,32,-5,2,14},i,m=5;
printf("排序前的数据:");
for(i=0;i<m;i++)
printf("%d",arr[i]);
printf("n");
proc(arr,m);
printf("排序后的顺序:");
for(i=0;i<m;i++)
printf("%d",arr[i]);
printf("/n");
}

(分数:30.00)
解析:错误:for(j=0;j<n-1;j++);
正确:for(j=0;j<n-1;j++)
错误:a[p]=t;
正确:a[i]=t; [解析] for循环结束的标志是for后的一个语句,如果for后面直接跟一个分号,
说明是一个空循环不执行任何功能,因此“for(j=0;j<n-1;j++);”后面的分号应该去掉;当a[i]<a[p]时两元素互换,因此“a[p]=t;”应改为“a[j]=t”。
三、程序设计题(总题数:1,分数:40.00)
3.请编写函数proc(),该函数的功能是:将放在字符串数组中的M个字符串(每串的长度不超过N),按顺序合并组成一个新的字符串。
例如,若字符串数组中的M个字符串为:
ABCD
BCDEFG
CDEFGHI
则合并后的字符串内容应该是:ABCDBCDEFGCDEFGHI。
注意:部分源程序给出如下。
请勿改动main()函数和其他函数中的任何内容,仅在函数proc()的花括号中填入所编写的若干语句。
试题程序:
#include<stdio.h>
#include<conio.h>
#define M 3
#define N 20
void proc(char arr[M][N],char*b)
{
}
void main()
{
char str[M][N]={"ABCD","BCDEFG","CDEFGHI"},i;
char arr[100]={">>>###"}; printf("The string:n");
for(i=0;i<M;i++)
c语言用递归函数求n的阶乘puts(str[i]);
printf("/n");
proc(str,arr);
printf("The A string:n");
printf("%s",arr);
printf("/n/n");
}

(分数:40.00)
__________________________________________________________________________________________
正确答案:()
解析:void proc(char arr[M][N].char*b)
{
int i,j,k=0;
for(i=0;i<M;i++) //i表示其行下标
for(j=0;arr[i][j]!="/0";j++)//由于每行的个数不等,因此用a[i][j]!="/0"来作为循环结束的条件
b[k++]=arr[i][j]; //把二维数组中的元素放到b的一维数组中,
b[k]="/0"; //最后给b赋"/0"作为字符串结束的标志
} [解析] 字符串数组中每一行都是一个完整的字符串,其结束标志为"/0"。因此,通过字符串的结束标志来判断每一个字符串是否结束,将字符串数组中的所有字符串均赋值给新的一维数组b来完成字符串的合并。

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。