第 1 頁:選擇題 |
第 5 頁:基本操作題 |
第 6 頁:參考答案 |
二、基本操作題
請補(bǔ)充函數(shù)proc(),函數(shù)proc()的功能是求7的階乘。
注意:部分源程序給出如下。
請勿改動(dòng)main()函數(shù)和其他函數(shù)中的任何內(nèi)容,僅在函數(shù)proc()的橫線上填入所編寫的若干表達(dá)式或語句。
試題程序:
#include
long proc(int n)
{
if( 【1】 )
return(n*proc( 【2】 );
else if(【3】)
return l;
}
void main()
{
int k=7:
printf("%d!=%ld\n",k,proc(k));
}
三、程序改錯(cuò)題
下列給定的程序中,函數(shù)proc()的功能是:用選擇法對數(shù)組中的m個(gè)元素按從小到大的順序進(jìn)行排序。
例如,排序前的數(shù)據(jù)為:11 32-5 2 14
則排序后的數(shù)據(jù)為:-5 2 11 14 32
請修改程序中的錯(cuò)誤,使它能得到正確結(jié)果。
注意:不要改動(dòng)main()函數(shù),不得增行或刪行,也不得更改程序的結(jié)構(gòu)。
試題程序:
#include
#define M 20
void proc(int a[],int n)
{
int i,j,t,P;
//****found****
for(j=0;j {
p=j;
for(i=j;i if(a[[i] p=i;
t=a[p];
a [p]=aEj3;
//****found****
a[p]=t;
}
}
void main()
{
int arr[M]={11,32,-5,2,14},i,m=5;
printf("排序前的數(shù)據(jù):");
for(i=0;i printf("%d",arr[i]);
printf("\n");
proc(arr,m);
printf("排序后的順序:");
for(i=0;i printf("%d",arr[i]);
printf("\n");
}
四、程序設(shè)計(jì)題
請編寫函數(shù)proc(),該函數(shù)的功能是:將放在字符串?dāng)?shù)組中的M個(gè)字符串(每串的長度
不超過N),按順序合并組成一個(gè)新的字符串。
例如,若字符串?dāng)?shù)組中的M個(gè)字符串為:
ABCD
BCDEFG
CDEFGHI
則合并后的字符串內(nèi)容應(yīng)該是ABCDBCDEFGCDEFGHl。
注意:部分源程序給出如下。
請勿改動(dòng)main()函數(shù)和其他函數(shù)中的任何內(nèi)容,僅在函數(shù)proc()的花括號(hào)中填入所編寫的若干語句。
試題程序:
#include
#include
#define M 3
#define N 20
void proc(char arr[M][N],char*b)
{
}
void main()
{
char str[M][N]={"ABCD","BCDEFG","CDEFGHl"),i;
char arr[100]={"##################"};
printf(”The strin9:kn”);
for(i=0;i puts(str[i]);
printf("\n");
proc(str,arr);
printf("The A string:\n");
printf("%S",arr);
printf("\n\n");
}
相關(guān)推薦:
2015年計(jì)算機(jī)二級(jí)C語言測試題及答案解析匯總
北京 | 天津 | 上海 | 江蘇 | 山東 |
安徽 | 浙江 | 江西 | 福建 | 深圳 |
廣東 | 河北 | 湖南 | 廣西 | 河南 |
海南 | 湖北 | 四川 | 重慶 | 云南 |
貴州 | 西藏 | 新疆 | 陜西 | 山西 |
寧夏 | 甘肅 | 青海 | 遼寧 | 吉林 |
黑龍江 | 內(nèi)蒙古 |