2011年C语言南开100题
2011年二级C语言南开100题
1: 第1题 m个人的成绩存放在score数组中,请编写函数fun,它的功能是:将低于平均分的人作为函数值返回,将低于平均分的分数放在below所指定的函数中。 答案:
int fun(int score[],int m,int below[]) {
int i,k=0,aver=0; for(i=0;i<m;i++) aver+=score[i]; aver/=m;
for(i=0;i<m;i++) if(score[i]<aver) {
below[k]=score[i]; k++; }
return k; }
2: 第2题 请编写函数fun,它的功能是:求出1到100之内能北7或者11整除,但不能同时北7和11整除的所有证书,并将他们放在a所指的数组中,通过n返回这些数的个数。 答案:
void fun(int *a, int *n) {
int i,j=0;
for(i=2;i<100;i++)
if ((i%7==0 || i==0) && iw!=0) a[j++]=i; *n=j; }
3: 第3题 请编写函数void fun(int x,int pp[],int *n),它的功能是:求出能整除x且不是偶数的各整数,并按从小到大的顺序放在pp所指的数组中,这些除数的个数通过形参n返回。 答案:
1
2011年C语言南开100题
void fun(int x, int pp[ ], int *n) {
int i=1,j=0;k=0,*t=pp; for(i=0;i<=x;i++) if(i%2!=0) { t[j]=I; j++; }
for(i=0;i<j;i++) if(x%t[i]==0) {
pp[k]=t[i]; k++; } *n=k; }
4: 第4题 请编写一个函数void fun(char *tt,int pp[]),统计在tt字符中\到\各字母各自出现的次数,并依次放在pp所指的数组中。 答案:
void fun(char *tt, int pp[]) { int i;
for (i=0;i<26;i++) pp[i]=0; while (*tt) {
switch (*tt) {
case ‘a’: pp[0]++;break; case ‘b’: pp[1]++;break; case ‘c’: pp[2]++;break; case ‘d’: pp[3]++;break; case ‘e’: pp[4]++;break; case ‘f’: pp[5]++;break; case ‘g’: pp[6]++;break; case ‘h’: pp[7]++;break; case ‘i’: pp[8]++;break; case ‘j’: pp[9]++;break; case ‘k’: pp[10]++;break; case ‘l’: pp[11]++;break;
2
2011年C语言南开100题
case ‘m’: pp[12]++;break; case ‘n’: pp[12]++;break; case ‘o’: pp[14]++;break; case ‘p’: pp[15]++;break; case ‘q’: pp[16]++;break; case ‘r’: pp[17]++;break; case ‘s’: pp[18]++;break; case ‘t’: pp[19]++;break; case ‘u’: pp[20]++;break; case ‘v’: pp[21]++;break; case ‘w’: pp[22]++;break; case ‘x’: pp[23]++;break; case ‘y’: pp[24]++;break; case ‘z’: pp[25]++;break; } tt++; } }
5: 第5题 请编写一个函数void fun(int m,int k,int xx[]),该函数的功能是:将大于整数m且紧靠m的k各素数存入xx所指的数组中。 答案:
void fun(int m, int k, int xx[]) {
int g=0,I,j,flag=1;
for(i=m+1;i<m*m;i++) {
for(j=0;j<I;j++) {
if(i%j!=0) flag=1; else {
flag=0; break; } }
if (flag==1 && j>=i) {
if (k>=0) {
xx[g++]=i; k--;
3
2011年C语言南开100题
} else break; } } }
6: 第6题 请编写一个函数void fun(char a[],char[],int n),其功能是:删除以各字符串中指定下标的字符。其中,a指向原字符串,删除后的字符串存放在b所指的数组中,n中存放指定的下标。 答案:
void fun(char a[],char b[], int n) {
int I,j=0;
for (i=0;i<LEN;i++) if (i!=n) {
b[j]=a[i]; j++; }
b[j]=‘\\0’; }
7: 第7题 请编写一个函数int fun(int *s,int t,int *k),用来求除数组的最大元素在数组中的下标并存放在k所指的储存单元中。 答案:
void fun (int *s, int t, int *k) {
int I, max; max=s[0];
for(i=0;i<t;i++) if (s[i]>max) {
max=s[i]; *k=I; } }
4