1、 函數(shù)調(diào)用:strcat(strcpy(str1,str2),str3)的功能是________。
創(chuàng)新互聯(lián)公司專(zhuān)注為客戶(hù)提供全方位的互聯(lián)網(wǎng)綜合服務(wù),包含不限于網(wǎng)站建設(shè)、成都網(wǎng)站制作、萬(wàn)秀網(wǎng)絡(luò)推廣、小程序開(kāi)發(fā)、萬(wàn)秀網(wǎng)絡(luò)營(yíng)銷(xiāo)、萬(wàn)秀企業(yè)策劃、萬(wàn)秀品牌公關(guān)、搜索引擎seo、人物專(zhuān)訪、企業(yè)宣傳片、企業(yè)代運(yùn)營(yíng)等,從售前售中售后,我們都將竭誠(chéng)為您服務(wù),您的肯定,是我們最大的嘉獎(jiǎng);創(chuàng)新互聯(lián)公司為所有大學(xué)生創(chuàng)業(yè)者提供萬(wàn)秀建站搭建服務(wù),24小時(shí)服務(wù)熱線(xiàn):18980820575,官方網(wǎng)址:www.cdcxhl.com
C) 將串str2復(fù)制到串str1中后再將串str3連接到串str1之后
2、 若有以下調(diào)用語(yǔ)句,則正確的fun函數(shù)首部是
main()
{ ∶
∶
int a;float x;
∶
∶
fun(x,a);
∶
∶
}
B) void fun(float a,int x)
3、 有如下程序
int func(int a,int b)
{ return(a+b); }
main()
{ int x=2,y=5,z=8,r;
r=func(func(x,y),z);
printf("%d\n",r); }
該程序的輸出結(jié)果是__________。
D) 15
4、 函數(shù)pi的功能是根據(jù)以下近似公式求π值:
(π*π)/6=1+1/(2*2)+1/(3*3)+……+1/(n*n)
請(qǐng)你在下面程序中的劃線(xiàn)部分填入________,完成求π的功能。
#include "math.h"
double pi(long n)
{ double s=0.0; long i;
for(i=1;i=n;i++) s=s+________;
return (sqrt(6*s)); }
A) 1.0/i/i
5、 在調(diào)用函數(shù)時(shí),如果實(shí)參是簡(jiǎn)單變量,它與對(duì)應(yīng)形參之間的數(shù)據(jù)傳遞
方式是________。
B) 單向值傳遞
6、 對(duì)于C語(yǔ)言的函數(shù),下列敘述中正確的是________。
A) 函數(shù)的定義不能嵌套,但函數(shù)調(diào)用可以嵌套 (這答案有待斟酌)
7、 函數(shù)f的功能是:測(cè)定字符串的長(zhǎng)度,空白處應(yīng)填入________。
int f(char s[ ])
{ int i=0;
while(s[i]!='\0') i++;
return (________); }
main( )
{ printf("%d\n",f("goodbye!")); }
B) i
8、 若主調(diào)用函數(shù)類(lèi)型為double,被調(diào)用函數(shù)定義中沒(méi)有進(jìn)行函數(shù)類(lèi)型
說(shuō)明,而return語(yǔ)句中的表達(dá)式類(lèi)型為float型,則被調(diào)函數(shù)返回
值的類(lèi)型是________。
C) double 型
9、 以下敘述中,錯(cuò)誤的是________。
D) 形參可以是常量、變量或表達(dá)式
10、 以下敘述中,不正確的是________。
B) 在main函數(shù)體內(nèi)定義的變量是全局變量
1.m個(gè)人的成績(jī)存放在score數(shù)組中,請(qǐng)編寫(xiě)函數(shù)fun,它的功能是:將低于平均分的人作為函數(shù)值返回,將低于平均分的分?jǐn)?shù)放在below所指定的函數(shù)中。
1.int fun(int score[],int m,int below[])
{int i,k=0,aver=0;
for(i-0;im;i++)
aver+=score[i];
aver/=m;
for(i=0,im;i++)
if(score[i]aver)
{below[k]=score[i];
k++;}
return k;}
2.請(qǐng)編寫(xiě)函數(shù)fun,它的功能是:求出1到100之內(nèi)能北7或者11整除,但不能同時(shí)北7和11整除的所有證書(shū),并將他們放在a所指的數(shù)組中,通過(guò)n返回這些數(shù)的個(gè)數(shù)。
2.void fun(int *a,int *n)
{int i,j=0;
for(i=2;i1000;i++)
if((i%7==0//i%11==0))i%77!=0)
a[j++]=i;
*n=j;}
3.請(qǐng)編寫(xiě)函數(shù)void fun(int x,int pp[],int *n),它的功能是:求出能整除x且不是偶數(shù)的各整數(shù),并按從小到大的順序放在pp所指的數(shù)組中,這些除數(shù)的個(gè)數(shù)通過(guò)形參n返回。
3. 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;ij;i++)
if(x%t[i]==0)
{pp[k]=t[i];
k++;}
*n=k;}
4.請(qǐng)編寫(xiě)一個(gè)函數(shù)void fun(char *tt,int pp[]),統(tǒng)計(jì)在tt字符中"a"到"z"26各字母各自出現(xiàn)的次數(shù),并依次放在pp所指的數(shù)組中。
4. void fun(char *tt,int pp[])
{int i;
for(i=0;i26;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;
case'm':pp[12]++;break;
case'n':pp[13]++;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.請(qǐng)編寫(xiě)一個(gè)函數(shù)void fun(int m,int k,int xx[]),該函數(shù)的功能是:將大于整數(shù)m且緊靠m的k各素?cái)?shù)存入xx所指的數(shù)組中。
5. void fun(int m,int k,int xx[])
{int g=0,i,j,flag=1;
for(i=m+1;im*m;i++)
{for(j=2;ji;j++)
{if (i%j!=0)
flag=1;
else
{flag=0;
break;}
}
if (flag==1j=i)
{if (k0)
{xx[g++]=i;
k--;}
else
break;}}}
6.請(qǐng)編寫(xiě)一個(gè)函數(shù)void fun(char a[],char[],int n),其功能是:刪除以各字符串中指定下標(biāo)的字符。其中,a指向原字符串,刪除后的字符串存放在b所指的數(shù)組中,n中存放指定的下標(biāo)。
6. void fun(char a[],char b[],int n)
{int i,j=0;
for (i=0;iLEN;i++)
if(i!=n)
{b[j]=a[i];
j++;}
b[j]='\0';}
7.請(qǐng)編寫(xiě)一個(gè)函數(shù)int fun(int *s,int t,int *k),用來(lái)求除數(shù)組的最大元素在數(shù)組中的下標(biāo)并存放在k所指的儲(chǔ)存單元中。
7. void fun(int *s,int t,int*k)
{int i,max;
max=s[0];
for (i=0;it;i++)
if (s[i]max)
{max=s[i];
*k=i; }}
8.編寫(xiě)函數(shù)fun,功能是:根據(jù)以下攻勢(shì)計(jì)算s,計(jì)算結(jié)果作為函數(shù)值返回;n通過(guò)形參傳入。s=1+1/(1+2)+1/(1+2+3)+.......+1/(1+2+3+4+......+n)
8. float fun(int n)
{int i;
float s=1.0,t=1.0;
for (i=2;i=n;i++)
{t=t+i;
s=s+1/t;}
return s;}
9.編寫(xiě)一個(gè)函數(shù)fun,它的功能是:根據(jù)以下公式求P的值,結(jié)果由函數(shù)值帶回。m與n為兩個(gè)正整數(shù),且要求mn。 p=m!/n!(m-n)!
9. p=m!/n!(m-n)!
float fun(int m,int n)
{float p,t=1.0;
int i;
for (i=1;i=m;i++)
t=t*i;
p=t;
for (t=1.0,i=1;i=n;i++)
t=t*i;
p=p/t;
for(t=1.0,i=1;im-n;i++)
t=t*i;
p=p/t;
return p;}
10.編寫(xiě)函數(shù)fun,它的功能是:利用以下的簡(jiǎn)單迭代方法求方程cos(x)-x=0的一個(gè)實(shí)根。
迭代步驟如下:(1)取x1初值為0.0; (2)x0=x1,把x1的值賦各x0;
(3)x1=cos(x0),求出一個(gè)新的x1;
(4)若x0-x1的絕對(duì)值小于0.000001,則執(zhí)行步驟(5),否則執(zhí)行步驟(2);
(5)所求x1就是方程cos(x)-x=0的一個(gè)實(shí)根,作為函數(shù)值返回。
程序?qū)⑤敵鯮oot=0.739085。
10. folat fun()
{float x1=0.0,x0;
do
{x0=x1;
x1=cos(x0); }
while (fabs(x0-x1)=1e-6);
return x1;}
11.下列程序定義了N×N的二維數(shù)組,并在主函數(shù)中自動(dòng)賦值。請(qǐng)編寫(xiě)函數(shù) fun(int a[][N]),該函數(shù)的功能是:使數(shù)組左下半三角元素中的值全部置成0。
11. int fun(int a[][N])
{int i,j;
for(i=0;iN;i++)
for(j=0;ji;j++)
a[i][j]=0;}
12.下列程序定義了N×N的二維數(shù)組,并在主函數(shù)中賦值。請(qǐng)編寫(xiě)函數(shù)fun,函數(shù)的功能使求出數(shù)組周邊元素的平均值并作為函數(shù)值返回給主函數(shù)中的s。
12.double fun (int w[][N])
{int i,j,k=0;
double s=0.0;
for (j=0;jN;j++)
{s+=w[0][j];
k++;}
for (j=0;jN;j++)
{s+=w[N-1][j];
k++;}
for (i=1;i=N-2;i++)
{s+=w[i][0];
k++;}
return s/=k;}
13.請(qǐng)編寫(xiě)一個(gè)函數(shù)void fun(int tt[M][N],int pp[N]),tt指向一個(gè)M行N列的二維函數(shù)組,求出二維函數(shù)組每列中最小元素,并依次放入pp所指定一維數(shù)組中。二維數(shù)組中的數(shù)已在主函數(shù)中賦予。
13. void fun(int tt[M][N],int pp[N])
{int i,j,min;
for (j=0;jN;j++)
{min=tt[0][j];
for (i=0;iM;i++)
{if (tt[i][j]min)
min=tt[i][j];}
pp[j]=min;}}
14.請(qǐng)別寫(xiě)函數(shù)fun,函數(shù)的功能使求出二維數(shù)組周邊元素之和,作為函數(shù)值返回。二維數(shù)組中的值在主函數(shù)中賦予。
14. int fun (int a[M][N])
{int i,j,s=0;
for (j=0;jN;j++)
{s+=a[0][j];
s+=a[M-1][j];}
for (i=1;i=M-2;i++)
{s+=a[i][0];
s+=a[i][N-1];}
return s;}
15.請(qǐng)編寫(xiě)一個(gè)函數(shù)unsigned fun(unsigned w),w使一個(gè)大于10的無(wú)符號(hào)整數(shù),若w使n(n≥2)位的整數(shù),則函數(shù)求出w后n-1位的數(shù)作為函數(shù)值返回。
15. unsigned fun(unsigned w)
{unsigned t,s=0,s1=1,p=0;
t=w;
while(t10)
{if(t/10)
p=t%10;
s=s+p*s1;
s1=s1*10;
t=t/10; }
return s;}
16.請(qǐng)編寫(xiě)一個(gè)函數(shù)float fun(double h),函數(shù)的功能使對(duì)變量h中的值保留2位小樹(shù),并對(duì)第三位進(jìn)行四舍五入(規(guī)定h中的值位正數(shù))。
16. float fun (float h)
{long t;
float s;
h=h*1000;
t=(h+5)/10;
s=(float)t/100.0;
return s;}
17.請(qǐng)編寫(xiě)一個(gè)函數(shù)fun(char *s),該函數(shù)的功能使把字符串中的內(nèi)容擬置。
17. void fun(char *s)
{char ch;
int i,m,n;
i=0;
m=n=strlen(s)-1;
while(i(n+1)/2)
{ch=s[i];
s[i]=s[m];
s[m]=ch;
i++;
m--;}}
18.編寫(xiě)程序,實(shí)現(xiàn)矩陣(3行3列)的轉(zhuǎn)置(即行列互換)。
18. void fun(int array[3][3])
{int i,j,temp;
for (i=0;i3;i++)
{temp=array[i][j];
array[i][j]=array[j][i];
array[j][i]=temp; }}
19.編寫(xiě)函數(shù)fun,該函數(shù)的功能是:從字符中刪除指定的字符,同一字母的大、小寫(xiě)按不同字符處理。
19. void fun(char s[],int c)
{int i=0;
char*p;
p=s;
while(*p)
{if(*p!=c)
{s[i]=*p;
i++;}
p++;}
s[i]='\0';}
20.編寫(xiě)函數(shù)int fun(int lim,int aa[MAX]),該函數(shù)的功能是求出小于或等于lim的所有素?cái)?shù)并放在aa數(shù)組中,該函數(shù)返回所求的素?cái)?shù)的個(gè)數(shù)。
20. int fun(int lim,int aa[MAX])
{int k=0,i,j;
for(i=lim;i1;i--)
{for(j=2;ji;j++)
if(i%j==0)
break;
else
continue;
if(j=i)
{aa[k]=i;
k++;}}
return k++;}
21.請(qǐng)編寫(xiě)函數(shù)fun,對(duì)長(zhǎng)度位7個(gè)字符的字符串,除首尾字符外,將其余5個(gè)字符按ASCII碼降序排列。
21.void fun(char *s,int num)
{char t;
int i,j;
for (i=1;inum-2;i++)
for (j=i+1;jnum-1;j++)
if(s[i]s[j])
{t=s[i];
s[i]=s[j];
s[j]=t;}}
22.N名學(xué)生的成績(jī)已在主函數(shù)中放入一個(gè)帶頭節(jié)點(diǎn)的鏈表結(jié)構(gòu)中,h指向鏈表的頭節(jié)點(diǎn)。請(qǐng)編寫(xiě)函數(shù)fun,它的功能是:找出學(xué)生的最高分,由函數(shù)值返回。
22. double fun (STREC *h)
{ double max;
STREC *q=h;
max=h-s;
do
{if(q-smax)
max=q-s;
q=q-next; }
while(q!=0);
return max;}
23.請(qǐng)編寫(xiě)函數(shù)fun,該函數(shù)的功能是:判斷字符串是否為回文?若是則函數(shù)返回1,主函數(shù)中輸出YES,否則返回0,主函數(shù)中輸出NO?;匚氖侵疙樧x和倒讀都是一樣的字符串。
23. int fun(char *str)
{int i,n=0,fg=1;
char *p=str;
while (*p)
{n++;
p++;}
for (i=0;in/2;i++)
if (str[i]==str[n-1-i]);
else
{fg=0;
break;}
return fg;}
24.請(qǐng)編寫(xiě)一個(gè)函數(shù)fun,它的功能是:將一個(gè)字符串轉(zhuǎn)換為一個(gè)整數(shù)(不得調(diào)用C語(yǔ)言提供的將字符串轉(zhuǎn)換為整數(shù)的函數(shù))。
24. long fun(char *p)
{long s=0,t;
int i=0,j,n=strlen(p),k,s1;
if(p[0]=='-')
i++;
for(j=i;j=n-1;j++)
{t=p[j]-'0';
s1=10;
for (k=j;kn-1;k++)
t*=s1;
s+=t; }
if(p[0]=='-')
return -s;
else
return s;}
25.請(qǐng)編寫(xiě)一個(gè)函數(shù)fun,它的功能是:比較兩個(gè)字符串的長(zhǎng)度,(不得調(diào)用C語(yǔ)言提供的求字符串長(zhǎng)度的函數(shù)),函數(shù)返回較長(zhǎng)的字符串。若兩個(gè)字符串長(zhǎng)度相同,則返回第一個(gè)字符串。
25. char *fun(char *s,char *t)
{char *p,*t1=t,*s1=s;
int n=0,m=0;
while(*s1)
{n++;
s1++;}
while(*t1)
{m++;
t1++;}
if(n=m)
p=s;
else
p=t;
return p;}
26.請(qǐng)編寫(xiě)一個(gè)函數(shù)fun,它的功能是:根據(jù)以下公式求X的值(要求滿(mǎn)足精度0.0005,即某項(xiàng)小于0.0005時(shí)停止迭代):
X/2=1+1/3+1×2/3×5+1×2×3/3×5×7+1×2×3×4/3×5×7×9+...+1×2×3×...×n/3×5×7×(2n+1)
程序運(yùn)行后,如果輸入精度0.0005,則程序輸出為3.14...。
26. double fun(double eps)
{double s;
float n,t,pi;
t=1;pi=0;n=1.0;s=1.0;
while((fabs(s))=eps)
{pi+=s;
t=n/(2*n+1);
s*=t;
n++;}
pi=pi*2;
return pi;}
27.請(qǐng)編寫(xiě)一個(gè)函數(shù)fun,它的功能是:求除1到m之內(nèi)(含m)能北7或11整除的所有整數(shù)放在數(shù)組a中,通過(guò)n返回這些數(shù)的個(gè)數(shù)。
27.void fun(int m,int *a,int *n)
{int i,j;*n=0;
for(i=1;i=m;i++)
if(i%7==0//i%11==0)
{a[j]=i;
j++;}
*n=j;}
28.請(qǐng)編寫(xiě)一個(gè)函數(shù)fun,它的功能是:找出一維整型數(shù)組元素中最大的值和它所在的下標(biāo),最大的值和它所在的下標(biāo)通過(guò)形參傳回。數(shù)組元素中的值已在主函數(shù)中賦予。主函數(shù)中x是數(shù)組名,n 是x中的數(shù)據(jù)個(gè)數(shù),max存放最大值,index存放最大值所在元素的下標(biāo)。
28. void fun(int a[],int n, int *max,int *d)
{int i;
*max=a[0];
*d=0;
for(i=0;in;i++)
if(a[i]*max)
{*max=a[i];
*d=i;}}
29.請(qǐng)編寫(xiě)一個(gè)函數(shù)fun,它的功能是:將ss所指字符串中所有下標(biāo)為奇數(shù)位置上的字母轉(zhuǎn)換為大寫(xiě)(若該位置上不是字母,則不轉(zhuǎn)換)。
29. void fun(char *ss)
{int i,n;
n=strlen(ss);
for(i=1;in;i+=2;)
if(ss[i]='a'ss[i]='z')
ss[i]=ss[i]-32;}
30.請(qǐng)編寫(xiě)一個(gè)函數(shù)fun,它的功能是:求除一個(gè)2×M整型二維數(shù)組中最大元素的值,并將此值返回調(diào)用函數(shù)。
30. int fun(int a[][M])
{int i,j,max;
max=a[0][0];
for(i=0;i2;i++)
for(j=0;jM;j++)
if(a[i][j]max)
max=a[i][j];
return max;}
31.請(qǐng)編寫(xiě)函數(shù)fun,其功能是:將s所指字符串中除了下標(biāo)為偶數(shù)、同時(shí)ASCII值也為偶數(shù)的字符外,其余的全都刪除;串中剩余字符所形成的一個(gè)新串放在t所指的一個(gè)數(shù)組中。
31. void fun(char *s,char t[])
{int i,j,n;
n=strlen(s);
for(i=0;in;i++)
if(i%2==0s[i]%2==0)
{t[j]=s[j];
j++;}
t[j]='\0';}
32.請(qǐng)編寫(xiě)函數(shù)fun,其功能是:將s所指字符串中除了下標(biāo)為奇數(shù)、同時(shí)ASCII值也為奇數(shù)的字符之外,其余的所有字符都刪除,串中剩余字符所形成的一個(gè)新串放在t所指的一個(gè)數(shù)組中。
32. void fun(char *s,char t[])
{int i,j=0,n;
n=strlen(s);
for(i=0;in;i++)
if(i%2!=0s[i]%2!=0)
{t[j]=s[j];
j++;}
t[j]='\0';}
33.假定輸入的字符串中只包含字母和*號(hào)。請(qǐng)編寫(xiě)函數(shù)fun,它的功能是:使字符串中尾部的*號(hào)不得多于n個(gè);若多于n個(gè),則刪除多于的*號(hào);若少于或等于n個(gè),則什么也不做,字符串中間和前面的*號(hào)不刪除。
33. void fun(char *a,int n)
{int i=0,k=0;
char *p,*t;
p=t=a;
while(*t)
t++;
t--;
while(*t--'*')
{k++;
t--;}
t++;
if(kn)
{while(*ppt+n)
{a[i]=*p;
i++;
p++;}
a[i]='\0'; }}
34.學(xué)生的記錄由學(xué)號(hào)和成績(jī)組成,N名學(xué)生的數(shù)據(jù)已在主函數(shù)中放入結(jié)構(gòu)體數(shù)組s中,請(qǐng)編寫(xiě)函數(shù)fun,它的功能使:把分?jǐn)?shù)最高的學(xué)生數(shù)據(jù)放在h所指的數(shù)組中,注意:分?jǐn)?shù)最高的學(xué)生可能不止一個(gè),函數(shù)返回分?jǐn)?shù)最高的學(xué)生的人數(shù)。
34. int fun(STREC*a,STREC *b)
{int i,j=0,max;
max=a[0].s;
for(i=0;iN;i++)
if(a[i].s==max)
{*(b+j)=a[i];
j++;
n++;}
return n;}
35.請(qǐng)編寫(xiě)一個(gè)函數(shù),用來(lái)刪除字符串中的所有空格。
35. void fun(char *str)
{int i=0;
char *p=str;
while(*p)
{if(*p!='')
{str[i]=*p;
i++;}
p++;}
str[i]='\0';}
36.假定輸入的字符串中只包含字母和*號(hào)。請(qǐng)編寫(xiě)函數(shù)fun,它的功能是:將字符串中的前導(dǎo)*號(hào)全部移到字符串的尾部。
36. void fun(char *a)
{int i=0,n=0;
char *p;
p=a;
while (*p=='*')
{n++;
p++;}
while (*p)
{a[i]=*p;
i++;
p++;}
while(n!=0)
{a[i]='*';
i++;
i--;}
a[i]='\0';}
37.某學(xué)生的記錄由學(xué)號(hào)、8門(mén)課程成績(jī)和平均分組成,學(xué)號(hào)和8門(mén)課程的成績(jī)已在主函數(shù)中給出。請(qǐng)編寫(xiě)函數(shù)fun,它的功能是:求出該學(xué)生的平均分放在記錄的ave成員中。請(qǐng)自己定義正確的形參。
37. void fun(STREC *p)
{double av=0.0;
int i;
for(i=0;iN;i++)
av+=p-s[i];
av/=N;
p-ave=av;}
38.請(qǐng)編寫(xiě)函數(shù)fun,它的功能是:求出ss所指字符串中指定字符的個(gè)數(shù),并返回此值。
38. int fun(char *ss,char c)
{int n=0;
while(*ss)
{if(*ss==c)
n++;
ss++;}
return n;}
39.請(qǐng)編寫(xiě)函數(shù)fun,該函數(shù)的功能是:移動(dòng)一維數(shù)組中的內(nèi)容,若數(shù)組中由n個(gè)整數(shù),要求把下標(biāo)從0到p(p小于等于n-1)的數(shù)組元素平移到數(shù)組的最后。
39. void fun(int *w,int p,int n)
{int b[N],i,j=0;
for(i=0;i=p;i++)
b[i]=w[i];
for(i=p+1;in;i++)
{w[j]=w[i];
j++;}
for(i=0;i=p;i++)
{w[j]=b[i];
j++;}}
40.請(qǐng)編寫(xiě)函數(shù)fun,該函數(shù)的功能是移動(dòng)字符串中內(nèi)容,移動(dòng)的規(guī)則如下:把第1到第m個(gè)字符,平移到字符串的最后,把第m+1到最后的字符移到字符串的前部。
40.void fun(char *w,int m)
{char b[N];
int i,j=0;
for(i=0;im;i++)
{b[j]=w[i];
j++;}
for(i=0;istrlen(w)-m;i++)
w[i]=w[i+m];
for(j=0;jm;j++)
{w[i]=b[j];
i++;}
w[i]='\0';}
41.請(qǐng)編寫(xiě)函數(shù)fun,該函數(shù)的功能是:將M行N列的二維數(shù)組中的字符數(shù)據(jù),按列的順序依次放到一個(gè)字符串中。
41. void fun(char (*s)[N],char *b)
{int i,j,k=0;
for(j=0;jn;j++)
for(i=0;iM;i++)
{b[k]=*(*(s+i)+j)
k++;}
b[k]='\0';}
42.下列程序定義了N×N的二維數(shù)組,并在主函數(shù)中自動(dòng)賦值。請(qǐng)編寫(xiě)函數(shù)fun(int a[][N],int m),該函數(shù)的功能是:將數(shù)組右上半三角元素中的值乘以m。
42. void fun(int a[][N],int m)
{int i,j;
for(j=0;jN;j++)
for(i=0;i=j;i++)
a[i][j]=a[i][j]*m;}
43.編寫(xiě)一個(gè)函數(shù),從傳入的num個(gè)字符串中找出一個(gè)最長(zhǎng)的一個(gè)字符串,并通過(guò)形參指針max傳回該串地址(用****作為結(jié)束輸入的標(biāo)志)。
43. char *fun(char (*a)[81],int num)
{int i;
char *max;
max=a[0];
for(i=0;inum;i++)
if(strlen(max)strlen(a[i]))
max=a[i];
return max;}
44.編寫(xiě)一個(gè)函數(shù),該函數(shù)可以統(tǒng)計(jì)一個(gè)長(zhǎng)度為2的字符串在另一個(gè)字符串中出現(xiàn)的次數(shù)。
44. int fun(char *str,char *substr)
{int n;
char *p,*r;
n=0;
while(*str)
{p=str;
r=substr;
while(*r)
if(*r==*p)
{r++;
p++;}
else
break;
if(*r=='\0')
n++;
str++;}
return n;}
45.假定輸入的字符串中只包含字母和*號(hào)。請(qǐng)編寫(xiě)函數(shù)fun,它的功能是:只刪除字符串前導(dǎo)和尾部的*號(hào),串中字母之間的*號(hào)都不刪除。形參n 給出了字符串的長(zhǎng)度,形參h給出了字符串中前導(dǎo)*號(hào)的個(gè)數(shù),形參e給出了字符串中最后的*個(gè)數(shù)。在編寫(xiě)時(shí)不得使用C語(yǔ)言給提供得字符串函數(shù)。
45.void fun(char *a,int n,int h,int e)
{int i=0;
char *p;
for(p=a+h;pa+n-e;p++)
{*(a+i)=*p;
i++;}
*(a+i)='\0';}
46.學(xué)生得記錄由學(xué)號(hào)和成績(jī)組稱(chēng)個(gè),N名大學(xué)生得數(shù)據(jù)已在主函數(shù)中放入結(jié)構(gòu)體數(shù)組s中,請(qǐng)編寫(xiě)函數(shù)fun,它的功能時(shí):按分?jǐn)?shù)的高低排列學(xué)生的記錄,高分在前。
46. void fun(STREC a[])
{int i,j;
STREC t;
for(i=0;iN-1;i++)
for(j=i;sN;j++)
if(a[i].sa[j].s)
{t=a[i];
a[i]=a[j];
a[j]=t; }}
47.請(qǐng)編寫(xiě)一個(gè)函數(shù)void fun(char *ss),其功能時(shí):將字符串ss中所有下標(biāo)為奇數(shù)位置上的字母轉(zhuǎn)換為大寫(xiě)(若位置上不是字母,則不轉(zhuǎn)換)。
47. void fun(char *ss)
{int i,n=0;
char *p=ss;
while(*p)
{n++;
p++;}
for (i=0;in;i++)
if ((ss[i]='a'ss[i]='z')
ss[i]=ss[i]-32;
ss[i]='\0';}
48.請(qǐng)編寫(xiě)函數(shù)fun,其功能是:將兩個(gè)兩位數(shù)的正整數(shù)a,b合并成一個(gè)整數(shù)放在c中。合并的方式是:將a數(shù)的十位和個(gè)位依次放在c數(shù)的千位和十位上,b數(shù)的十位和個(gè)位數(shù)依次放在c數(shù)的百位和個(gè)位上。
48. void fun(int a,int b,long *c)
{*c=(a/10)*1000+(b/10)*100+(a%10)*10+b%10;}
49.請(qǐng)編寫(xiě)函數(shù)fun,其功能是:將s所指字符串中下標(biāo)位偶數(shù)同時(shí)ASCII值為奇數(shù)的字符刪除,s中剩余的字符形成的新串放在t所指的數(shù)組中。
49. void fun(char *s,char t[])
{int i,j=0,n=strlen(s);
for(i=0;in;i++)
if(i%2==0s[i]%2!=0)
else
{f[j]=s[i];
j++;}
t[j]='\0';}
50.已知學(xué)生的記錄是由學(xué)號(hào)和學(xué)習(xí)成績(jī)構(gòu)成,N名學(xué)生的數(shù)據(jù)已存入結(jié)構(gòu)體數(shù)組中。請(qǐng)編寫(xiě)函數(shù)fun,該函數(shù)的功能是:找出成績(jī)最高的學(xué)生記錄,通過(guò)形參返回主函數(shù)(規(guī)定只有一個(gè)最高分)。
50. void fun(STU a[],STU *s)
{int i,max;
max=a[0].s;
for (i=0;iN;i++)
if(a[i].smax)
{max=a[i].s;
*s=a[i];}}
51.請(qǐng)編寫(xiě)函數(shù)fun,其功能是:將所有大于1小于整數(shù)m的非素?cái)?shù)存入xx所指的數(shù)組中,非素?cái)?shù)的個(gè)數(shù)通過(guò)k傳回。
51. void fun(int m,int *k,int xx[])
{int i,j;
int t=0;
for(i=2;im;i++)
{j=2;
while(ji)
{if(i%j==0)
{xx[t]=i;
t++;
break;}
j++;}
*k=t;}}
52.編寫(xiě)一個(gè)函數(shù)fun,它的功能是:實(shí)現(xiàn)兩個(gè)字符串的連接(不使用庫(kù)函數(shù)strcat),即把p2所指的字符串連接到p1所指的字符串后。
52. void fun(char p1[],char p2[])
{int i=0,n=0;
char *p=p1,*q=p2;
while (*p)
{p++;
n++;}
i=n;
while(*p)
{p1[i]=*q;
q++;
i++;}
p1[i]='\0';}
53.請(qǐng)編寫(xiě)函數(shù)fun,該函數(shù)的功能是:實(shí)現(xiàn)B=A+A',即把矩陣A加上A的轉(zhuǎn)置,存放在矩陣B中。計(jì)算結(jié)果在main函數(shù)中輸出。
53. void fun(int a[3][3],int b[3][3])
{int i,j,at[3][3];
for(i=0;i=2;i++)
for(j=0;j=2;j++)
at[i][j]=a[j][i];
for(i=0;i3;i++)
for(j=0;j3;j++)
b[i][j]=a[i][j]+at[i][j];}
54.學(xué)生的記錄由學(xué)號(hào)和成績(jī)組稱(chēng)個(gè),N名學(xué)生的數(shù)據(jù)已在主函數(shù)中放入結(jié)構(gòu)體數(shù)組s中,請(qǐng)編寫(xiě)函數(shù)fun,它的功能是:把低于平均分的學(xué)生數(shù)據(jù)放在b所指的數(shù)組中,低于平均分的學(xué)生人數(shù)通過(guò)形參n傳回,平均分通過(guò)函數(shù)值返回。
54. double fun(STREC *a, STREC *b,int *n)
{double aver=0.0;
int i,j=0;
*n=0;
for (i=0;iN;i++)
aver+=a[i].s;
aver/=N;
for(i=0;iN;i++)
if(a[i].saver)
{b[j]=a[i];
(*n)++;
j++; }
return aver;}
#include?stdio.h
int?fun(int?n){
int?i;
if(n2??!(n1)?||?n2)
return?0;
for(i=3;i*i=n;i+=2)
if(!(n%i))
return?0;
return?1;
}
int?main(void){
int?s[8],i;
printf("Input?8?integers...\n");
for(i=0;i8;scanf("%d",s+i++));
printf("The?prime?Numbers:\n");
for(i=0;i8;i++)
if(fun(s[i]))
printf("%d?",s[i]);
printf("\nThe?sum?Numbers:\n");?
for(i=0;i8;i++)
if(!fun(s[i]))
printf("%d?",s[i]);
printf("\n");?
return?0;
}
樓上的你這樣是想把我笑死,好繼承我的小樹(shù)林嗎?哈哈哈敷衍也不要這樣隨便打字出來(lái)吧~
好了好了回歸正題,希望沒(méi)有太晚哈哈,隨便在電大題酷這個(gè)小程序上搜了一些題,不知道適不適合你呢?這個(gè)小程序還挺好用的,我覺(jué)得電大學(xué)生都應(yīng)該人手備一個(gè),如果你還想要其他的,建議你去這個(gè)小程序上搜其他的哦,希望能夠幫到你哦~~~~~~~~~~~~~~~~~~~~~
1 單選 C語(yǔ)言中函數(shù)返回值的類(lèi)型是由 ( A?。?決定的.
A. 函數(shù)定義時(shí)指定的類(lèi)型
B. return語(yǔ)句中的表達(dá)式類(lèi)型
C. 調(diào)用該函數(shù)時(shí)的實(shí)參的數(shù)據(jù)類(lèi)型
D. 形參的數(shù)據(jù)類(lèi)型
2 單選 在函數(shù)調(diào)用時(shí),以下說(shuō)法正確的是:( B?。?/p>
A. 函數(shù)調(diào)用后必須帶回返回值
B. 實(shí)際參數(shù)和形式參數(shù)可以同名
C. 函數(shù)間的數(shù)據(jù)傳遞不可以使用全局變量
D. 主調(diào)函數(shù)和被調(diào)函數(shù)總是在同一個(gè)文件里
3 單選 語(yǔ)句int *p;說(shuō)明了( C )。
A. p是指向一維數(shù)組的指針
B. p是指向函數(shù)的指針
C. p是指向int型數(shù)據(jù)的指針
D. p是函數(shù)名,該函數(shù)返回一指向int型數(shù)據(jù)的指針
4 單選 下列指針的定義不正確的定義是( A )。
A. int *p=i,i;
B. int *p,i;
C. int i,*p=i;
D. int i,*p;
5 單選 有語(yǔ)句:int a[10],;則( B?。┦菍?duì)指針變量p的正確定義和初始化。
A. int p=*a;
B. int *p=a;
C. int p=a;
D. int *p=a;
6 單選 若有說(shuō)明語(yǔ)句“int a[5],*p=a;”,則對(duì)數(shù)組元素的正確引用是:( C )。
A. a[p]
B. p[a]
C. *(p+2)
D. p+2
7 單選
有如下程序
int a[10]={1,2,3,4,5,6,7,8,9,10},*p=a;
則數(shù)值為9的表達(dá)式是:( B?。?。
A. *p+9
B. *(p+8)
C. *p+=9
D. p+8
8 單選 被調(diào)函數(shù)調(diào)用結(jié)束后,返回到 :( D?。?/p>
A. 主調(diào)函數(shù)中該被調(diào)函數(shù)調(diào)用語(yǔ)句處
B. 主函數(shù)中該被調(diào)函數(shù)調(diào)用語(yǔ)句處
C. 主調(diào)函數(shù)中該被調(diào)函數(shù)調(diào)用語(yǔ)句的前一語(yǔ)句
D. 主調(diào)函數(shù)中該被調(diào)函數(shù)調(diào)用語(yǔ)句的后一語(yǔ)句
9 單選 能把函數(shù)處理結(jié)果的兩個(gè)數(shù)據(jù)返回給主調(diào)函數(shù),在下面的方法中不正確的是:( A )。
A. return 這兩個(gè)數(shù)
B. 形參用兩個(gè)元素的數(shù)組
C. 形參用兩個(gè)這種數(shù)據(jù)類(lèi)型的指針
D. 用兩個(gè)全局變量
10 單選 下列各語(yǔ)句定義了數(shù)組,其中哪一個(gè)是不正確的( C )。
A. char a[3][10]={"China","American","Asia"};
B. int x[2][2]={1,2,3,4};
C. float x[2][ ]={1,2,4,6,8,10};
D. int m[][3]={1,2,3,4,5,6};
11 單選 # include stdio.hint test(int b){ b*=10;printf(“b=%d ”,b);return b/2;}void main(){ int b=60;b=test(b);printf(“b=%d ”,b);}程序的運(yùn)行結(jié)果是:( D )。
A. b=10 b=60
B. b=10 b=30
C. b=300 b=600
D. b=600 b=300
12 單選 如果一個(gè)函數(shù)作為表達(dá)式被調(diào)用,則該函數(shù)必須是 ( A )。
A. 有返回值的函數(shù)
B. 無(wú)返回值的函數(shù)
C. 有參函數(shù)
D. 無(wú)參函數(shù)
13 單選 C語(yǔ)言程序由函數(shù)組成,它的( B )。
A. 主函數(shù)必須在其它函數(shù)之前,函數(shù)內(nèi)可以嵌套定義函數(shù)。
B. 主函數(shù)可以在其它函數(shù)之后,函數(shù)內(nèi)不可以嵌套定義函數(shù)。
C. 主函數(shù)必須在其它函數(shù)之前,函數(shù)內(nèi)不可以嵌套定義函數(shù)。
D. 主函數(shù)可以在其它函數(shù)之后,函數(shù)內(nèi)可以嵌套定義函數(shù)。
14 單選 下列表達(dá)式中,與下標(biāo)引用a[k]等效的是:( A )。
A. *(a+k)
B. a+k
C. *a+k
D. a+*k
15 單選 下列結(jié)論中,只有( D )是不正確的。
A. C語(yǔ)言不允許函數(shù)嵌套定義。
B. C語(yǔ)言允許函數(shù)嵌套調(diào)用。
C. C語(yǔ)言中允許函數(shù)遞歸調(diào)用。
D. C語(yǔ)言所有函數(shù)都可以相互調(diào)用,包括調(diào)用main。