真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

c語(yǔ)言數(shù)組和函數(shù)面試題,c語(yǔ)言c++面試題

推薦一些有關(guān)C語(yǔ)言數(shù)組的練習(xí)題。

06年南開上機(jī)題

創(chuàng)新互聯(lián)公司是一家以網(wǎng)站建設(shè)公司、網(wǎng)頁(yè)設(shè)計(jì)、品牌設(shè)計(jì)、軟件運(yùn)維、成都網(wǎng)站推廣、小程序App開發(fā)等移動(dòng)開發(fā)為一體互聯(lián)網(wǎng)公司。已累計(jì)為成都OPP膠袋等眾行業(yè)中小客戶提供優(yōu)質(zhì)的互聯(lián)網(wǎng)建站和軟件開發(fā)服務(wù)。

1: 第1題 m個(gè)人的成績(jī)存放在score數(shù)組中,請(qǐng)編寫函數(shù)fun,它的功能是:將低于平均分的人作為函數(shù)值返回,將低于平均分的分?jǐn)?shù)放在below所指定的函數(shù)中。

答案: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題 請(qǐng)編寫函數(shù)fun,它的功能是:求出1到100之內(nèi)能北7或者11整除,但不能同時(shí)北7和11整除的所有證書,并將他們放在a所指的數(shù)組中,通過(guò)n返回這些數(shù)的個(gè)數(shù)。

答案:void fun(int *a, int *n)

{

int i,j=0;

for(i=2;i<1000;i++)

if ((i%7==0 || i%11==0) i%77!=0)

a[j++]=i;

*n=j;

}

3: 第3題 請(qǐng)編寫函數(shù)void fun(int x,int pp[],int *n),它的功能是:求出能整除x且不是偶數(shù)的各整數(shù),并按從小到大的順序放在pp所指的數(shù)組中,這些除數(shù)的個(gè)數(shù)通過(guò)形參n返回。

答案: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題 請(qǐng)編寫一個(gè)函數(shù)void fun(char *tt,int pp[]),統(tǒng)計(jì)在tt字符中"a"到"z"26各字母各自出現(xiàn)的次數(shù),并依次放在pp所指的數(shù)組中。

答案:void fun(char *tt, int pp[])

{

int i;

for (i=0;i<26;i++)

pp[i]=0;

while (*tt)

{

switch (*tt)

{

case ‘a(chǎn)’: 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[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題 請(qǐng)編寫一個(gè)函數(shù)void fun(int m,int k,int xx[]),該函數(shù)的功能是:將大于整數(shù)m且緊靠m的k各素?cái)?shù)存入xx所指的數(shù)組中。

答案: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--;

}

else

break;

}

}

}

6: 第6題 請(qǐng)編寫一個(gè)函數(shù)void fun(char a[],char[],int n),其功能是:刪除以各字符串中指定下標(biāo)的字符。其中,a指向原字符串,刪除后的字符串存放在b所指的數(shù)組中,n中存放指定的下標(biāo)。

答案: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題 請(qǐng)編寫一個(gè)函數(shù)int fun(int *s,int t,int *k),用來(lái)求除數(shù)組的最大元素在數(shù)組中的下標(biāo)并存放在k所指的儲(chǔ)存單元中。

答案: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;

}

}

8: 第8題 編寫函數(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)

答案: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: 第9題 編寫一個(gè)函數(shù)fun,它的功能是:根據(jù)以下公式求p的值,結(jié)果由函數(shù)值帶回。M與n為兩個(gè)正整數(shù),且要求mn。 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;i<=m-n;i++)

t=t*I;

p=p/t;

return p;

}

10: 第10題 編寫函數(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。

答案:float fun()

{

float x1=0.0,x0;

do

{

x0=x1;

x1=cos(x0);

}

while(fabs(x0-x1)1e-6);

return x1;

}

11: 第11題 下列程序定義了n×n的二維數(shù)組,并在主函數(shù)中自動(dòng)賦值。請(qǐng)編寫函數(shù) fun(int a[][n]),該函數(shù)的功能是:使數(shù)組左下半三角元素中的值全部置成0。

答案:int fun(int a[][N])

{

int I,j;

for(i=0;i<N;i++)

for(j=0;j<=I;j++)

a[i][j]=0;

}

12: 第12題 下列程序定義了n×n的二維數(shù)組,并在主函數(shù)中賦值。請(qǐng)編寫函數(shù)fun,函數(shù)的功能使求出數(shù)組周邊元素的平均值并作為函數(shù)值返回給主函數(shù)中的s。

答案:double fun(int w[][N])

{

int I,j,k=0;

double s=0.0;

for(j=0;j<N;j++)

{

s+=w[0][j];

k++;

}

for(j=0;j<N;j++)

{

s+=w[N-1][j];

k++;

}

for(i=1;i<=N-2;i++)

{

s+=w[i][0];

k++;

}

for(i=1;i<=N-2;i++)

{

s+=w[i][N-1];

k++;

}

return s/=k;

}

13: 第13題 請(qǐng)編寫一個(gè)函數(shù)void fun(int tt[m][n],int pp[n]),tt指向一個(gè)m行n列的二維函數(shù)組,求出二維函數(shù)組每列中最小元素,并依次放入pp所指定一維數(shù)組中。二維數(shù)組中的數(shù)已在主函數(shù)中賦予。

答案:void fun(int tt[M][N], int pp[N])

{

int I,j,min;

for(j=0;j<N;j++)

{

min=tt[0][j];

for(i=0;i<M;i++)

{

if (tt[i][j]<min)

min=tt[i][j];

}

pp[j]=min;

}

}

14: 第14題 請(qǐng)別寫函數(shù)fun,函數(shù)的功能使求出二維數(shù)組周邊元素之和,作為函數(shù)值返回。二維數(shù)組中的值在主函數(shù)中賦予。

答案:int fun(int a[M][N])

{

int I,j,s=0;

for(j=0;j<N;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: 第15題 請(qǐng)編寫一個(gè)函數(shù)unsigned fun(unsigned w),w使一個(gè)大于10的無(wú)符號(hào)整數(shù),若w使n(n≥2)位的整數(shù),則函數(shù)求出w后n-1位的數(shù)作為函數(shù)值返回。

答案: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: 第16題 請(qǐng)編寫一個(gè)函數(shù)float fun(double h),函數(shù)的功能使對(duì)變量h中的值保留2位小樹,并對(duì)第三位進(jìn)行四舍五入(規(guī)定h中的值位正數(shù))。

答案:float fun(float h)

{

long t;

float s;

h=h*1000;

t=(h+5)/10;

s=(float)t/100.0;

return s;

}

17: 第17題 請(qǐng)編寫一個(gè)函數(shù)fun(char *s),該函數(shù)的功能使把字符串中的內(nèi)容擬置。

答案: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: 第18題 編寫程序,實(shí)現(xiàn)矩陣(3行3列)的轉(zhuǎn)置(即行列互換)。

答案:void fun(int array[3][3])

{

int I,j,temp;

for(i=0;i<3;i++)

for(j=0;j<I,j++)

{

temp=array[i][j];

array[i][j]=array[j][i];

array[j][i]=temp;

}

}

19: 第19題 編寫函數(shù)fun,該函數(shù)的功能是:從字符中刪除指定的字符,同一字母的大、小寫按不同字符處理。

答案: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: 第20題 編寫函數(shù)int fun(int lim,int aa[max]),該函數(shù)的功能是求出小于或等于lim的所有素?cái)?shù)并放在aa數(shù)組中,該函數(shù)返回所求的素?cái)?shù)的個(gè)數(shù)。

答案:int fun(int lim, int aa[MAX])

{

int k=0,I,j;

for(i=lim;i1;i--)

{

for(j=2;j<i;j++)

if(i%j==0)

break;

else

continue;

if(j=i)

{

aa[k]=i;

k++;

}

}

return k++;

}

21: 第21題 請(qǐng)編寫函數(shù)fun,對(duì)長(zhǎng)度位7個(gè)字符的字符串,除首尾字符外,將其余5個(gè)字符按ascii碼降序排列。

答案:void fun(char *s,int num)

{

char t;

int I,j;

for(i=1;i<num-2;i++)

for(j=i+1;j<num-1;j++)

if(s[i]<s[j])

{

t=s[i];

s[i]=s[j];

s[j]=t;

}

}

22: 第22題 n名學(xué)生的成績(jī)已在主函數(shù)中放入一個(gè)帶頭節(jié)點(diǎn)的鏈表結(jié)構(gòu)中,h指向鏈表的頭節(jié)點(diǎn)。請(qǐng)編寫函數(shù)fun,它的功能是:找出學(xué)生的最高分,由函數(shù)值返回。

答案: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: 第23題 請(qǐng)編寫函數(shù)fun,該函數(shù)的功能是:判斷字符串是否為回文?若是則函數(shù)返回1,主函數(shù)中輸出yes,否則返回0,主函數(shù)中輸出no?;匚氖侵疙樧x和倒讀都是一樣的字符串。

答案:int fun(char *str)

{

int I,n=0;fg=1;

char *p=str;

while (*p)

{

n++;

p++;

}

for(i=0;i<n/2;i++)

if (str[i]==str[n-1-i]);

else

{

fg=0;

break;

}

return fg;

}

24: 第24題 請(qǐng)編寫一個(gè)函數(shù)fun,它的功能是:將一個(gè)字符串轉(zhuǎn)換為一個(gè)整數(shù)(不得調(diào)用c語(yǔ)言提供的將字符串轉(zhuǎn)換為整數(shù)的函數(shù))。

答案: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;k<n-1;k++)

t*=s1;

s+=t;

}

if(p[0]==‘-’)

return –s;

else

return s;

}

25: 第25題 請(qǐng)編寫一個(gè)函數(shù)fun,它的功能是:比較兩個(gè)字符串的長(zhǎng)度,(不得調(diào)用c語(yǔ)言提供的求字符串長(zhǎng)度的函數(shù)),函數(shù)返回較長(zhǎng)的字符串。若兩個(gè)字符串長(zhǎng)度相同,則返回第一個(gè)字符串。

答案: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: 第26題 請(qǐng)編寫一個(gè)函數(shù)fun,它的功能是:根據(jù)以下公式求x的值(要求滿足精度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…。

答案: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: 第27題 請(qǐng)編寫一個(gè)函數(shù)fun,它的功能是:求除1到m之內(nèi)(含m)能北7或11整除的所有整數(shù)放在數(shù)組a中,通過(guò)n返回這些數(shù)的個(gè)數(shù)。

答案:void fun(int m, int *a, int *n)

{

int I,j=0; *n=0;

for(i=1;i<=m;i++)

if (i%7==0 || i%11 ==0)

{

a[j]=I;

j++;

}

*n=j;

}

28: 第28題 請(qǐng)編寫一個(gè)函數(shù)fun,它的功能是:找出一維整型數(shù)組元素中最大的值和它所在的下標(biāo),最大的值和它所在的下標(biāo)通過(guò)形參傳回。數(shù)組元素中的值已在主函數(shù)中賦予。主函數(shù)中x是數(shù)組名,n 是x中的數(shù)據(jù)個(gè)數(shù),max存放最大值,index存放最大值所在元素的下標(biāo)。

答案:void fun (int a[],int n, int *max, int *d)

{

int I;

*max=a[0];

*d=0;

for(i=0;I<n;i++)

if(a[i]*max)

{

*max=a[i];

*d=I;

}

}

29: 第29題 請(qǐng)編寫一個(gè)函數(shù)fun,它的功能是:將ss所指字符串中所有下標(biāo)為奇數(shù)位置上的字母轉(zhuǎn)換為大寫(若該位置上不是字母,則不轉(zhuǎn)換)。

答案:void fun(char *ss)

{

int I,n;

n=strlen(ss);

for(i=1;i<n;i+=2)

if(ss[i]=‘a(chǎn)’ ss[i]<=‘z’)

ss[i]=ss[i]-32;

}

30: 第30題 請(qǐng)編寫一個(gè)函數(shù)fun,它的功能是:求除一個(gè)2×m整型二維數(shù)組中最大元素的值,并將此值返回調(diào)用函數(shù)。

答案:int fun(int a[][M])

{

int I,j,max;

max=a[0][0];

for(i=0;i<2;i++)

for(j=0;j<M;j++)

if(a[i][j]max)

max=a[i][j];

return max;

}

31: 第31題 請(qǐng)編寫函數(shù)fun,其功能是:將s所指字符串中除了下標(biāo)為偶數(shù)、同時(shí)ascii值也為偶數(shù)的字符外,其余的全都刪除;串中剩余字符所形成的一個(gè)新串放在t所指的一個(gè)數(shù)組中。

答案:void fun(char *s,char t[])

{

int I,j=0,n;

n=strlen(s);

for(i=0;I,n;i++)

if(i%2==0s[i]%2==0)

{

t[j]=s[i];

j++;

}

t[j]=‘\0’;

}

32: 第32題 請(qǐng)編寫函數(shù)fun,其功能是:將s所指字符串中除了下標(biāo)為奇數(shù)、同時(shí)ascii值也為奇數(shù)的字符之外,其余的所有字符都刪除,串中剩余字符所形成的一個(gè)新串放在t所指的一個(gè)數(shù)組中。

答案:void fun(char *s,char t[])

{

int I,j=0,n;

n=strlen(s);

for(i=0;I,n;i++)

if(i%2!=0s[i]%2!=0)

{

t[j]=s[i];

j++;

}

t[j]=‘\0’;

}

33: 第33題 假定輸入的字符串中只包含字母和*號(hào)。請(qǐng)編寫函數(shù)fun,它的功能是:使字符串中尾部的*號(hào)不得多于n個(gè);若多于n個(gè),則刪除多于的*號(hào);若少于或等于n個(gè),則什么也不做,字符串中間和前面的*號(hào)不刪除。

答案: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 (*pp<t+n)

{

a[i]=*p;

i++;

p++;

}

a[i]=‘\0’;

}

}

34: 第34題 學(xué)生的記錄由學(xué)號(hào)和成績(jī)組成,n名學(xué)生的數(shù)據(jù)已在主函數(shù)中放入結(jié)構(gòu)體數(shù)組s中,請(qǐng)編寫函數(shù)fun,它的功能使:把分?jǐn)?shù)最高的學(xué)生數(shù)據(jù)放在h所指的數(shù)組中,注意:分?jǐn)?shù)最高的學(xué)生可能不止一個(gè),函數(shù)返回分?jǐn)?shù)最高的學(xué)生的人數(shù)。

答案:int fun (STREC *a, STREC *b)

{

int I,j=0,n=0, max;

max=a[0].s;

for(i=0;i<N;i++)

if(a[i].smax)

max=a[i].s;

for(i=0;i<N;i++)

if(a[i].s==max)

{

*(b+j)=a[i];

j++;

n++;

}

return n;

}

35: 第35題 請(qǐng)編寫一個(gè)函數(shù),用來(lái)刪除字符串中的所有空格。

答案:void fun(char *str)

{

int i=0;

char *p=str;

while (*p)

{

if(*p!=‘’)

{

str[i]=*p;

i++;

}

p++;

}

str[i]=‘\0’;

}

36: 第36題 假定輸入的字符串中只包含字母和*號(hào)。請(qǐng)編寫函數(shù)fun,它的功能是:將字符串中的前導(dǎo)*號(hào)全部移到字符串的尾部。

答案: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++;

n--;

}

a[i]=‘\0’;

}

37: 第37題 某學(xué)生的記錄由學(xué)號(hào)、8門課程成績(jī)和平均分組成,學(xué)號(hào)和8門課程的成績(jī)已在主函數(shù)中給出。請(qǐng)編寫函數(shù)fun,它的功能是:求出該學(xué)生的平均分放在記錄的ave成員中。請(qǐng)自己定義正確的形參。

答案:void fun(STREC *p)

{

double av=0.0;

int i:

for(i=0;i<N;i++)

av+=p-s[i];

av/=N;

p-ave=av;

}

c語(yǔ)言程序題,要用到數(shù)組和函數(shù)。謝謝,急求

通過(guò)冒泡法排序進(jìn)行處理,具體的看代碼。

/*

此程序能實(shí)現(xiàn)如下功能:

1)從鍵盤上輸入n個(gè)整數(shù)(n的值由用戶指定,n1000)存入一數(shù)組中,

將它們按照從小到大的順序排列起來(lái),輸出排列后的數(shù)組值;

2)檢查整數(shù)x(由用戶指定)值是否在這些數(shù)字當(dāng)中,若在,返回

其在數(shù)組中的位置(即下標(biāo)值,可能不止一個(gè)),若不在則將x插

入到相應(yīng)位置,插入后數(shù)組仍有序;

3)統(tǒng)計(jì)數(shù)組中大于a小于b的元素個(gè)數(shù)并輸出,a、b值由用戶指定

*/

#include?stdio.h

void?bubble_sort(int?a[],?int?n)

{

/*?

冒泡法排序

*/

int?i,?j,?temp;

for?(j?=?0;?j??n?-?1;?j++)

for?(i?=?0;?i??n?-?1?-?j;?i++)

{

if(a[i]??a[i?+?1])

{

temp?=?a[i];

a[i]?=?a[i?+?1];

a[i?+?1]?=?temp;

}

}

}

int?find(int?x,?int?a[],?int?n)

{

/*?

從已從小到大排序的數(shù)組中查找一個(gè)值,

并輸出其所在的下標(biāo),若不在,即將其插入到相應(yīng)的位置

返回值判斷數(shù)組中是否插入了輸入的值

*/

int?i;

int?flag?=?0;

int?tmp[2];

int?j?=?0;

for(i?=?0;?i??n;?i++)

{

if(a[i]?==?x)

{

flag?=?1;

break;

}

else?if(a[i]??x)

break;

}

if(?flag?==?1)

{

printf("%d存在于數(shù)組中,其下標(biāo)為:",x);

while(i??n)

{

printf("%d?",i++);

if(a[i]?!=?x)

break;

}

putchar('\n');

return?0;

}

else{

printf("%d不存在于數(shù)組中\(zhòng)n",x);

tmp[j++]?=?a[i];

a[i++]?=?x;

/*?對(duì)后面的數(shù)組進(jìn)行重新排序?*/

while(i??n?+?1)

{

tmp[(j++)%2]?=?a[i];

a[i++]?=?tmp[j%2];

}

printf("插入%d后,重新排序后的數(shù)組為:",x);

for(i?=?0;?i??n?+?1;?i++)

printf("%d?",a[i]);

putchar('\n');

return?1;

}

}

void?find_a_b(int?a,?int?b,?int?c[],?int?n)

{

/*?統(tǒng)計(jì)已排序數(shù)組中大于a,小于b的個(gè)數(shù)?*/

int?i;

int count;

for(i?=?0,count?=?0;?i??n;?i++)

{

if(c[i]??a)

if(c[i]??b)

count++;

else

break;

}

if(count?==?0)

printf("數(shù)組中大于%d,小于%d的元素個(gè)數(shù)為0\n",a,b);

else

{

printf("數(shù)組中大于%d,小于%d的元素個(gè)數(shù)為%d\n",a,b,count);

printf("它們?yōu)椋?);

for(i?-=?count;?count??0;?count--)

printf("%d?",c[i++]);

putchar('\n');

}

}

int?main()

{

int a[1000];

int n;

int x;

int i;

/*?以下指定輸入的整數(shù)的個(gè)數(shù),及完成數(shù)據(jù)的輸入?*/

printf("請(qǐng)輸入要輸入的整數(shù)的個(gè)數(shù)n(n1000):");

scanf("%d",n);

printf("請(qǐng)輸入%d個(gè)整數(shù)值:",n);

for(i?=?0?;?i??n;?i++)

scanf("%d",a[i]);

/*?對(duì)數(shù)組進(jìn)行排序后,輸出?*/

bubble_sort(a,n);

printf("排序后的數(shù)組為:");

for(i?=?0?;?i??n;?i++)

printf("%d?",a[i]);

printf("\n");

/*?在數(shù)組中查找或插入一個(gè)值?*/

printf("請(qǐng)輸入要查找或插入的數(shù)值:");

scanf("%d",x);

n?+=?find(x,a,n);

/*?統(tǒng)計(jì)數(shù)組中大于a,小于b的個(gè)數(shù)并輸出?*/

int?a1,b;

printf("請(qǐng)依次輸入a,b的值(ab):");

scanf("%d%d",a1,b);

find_a_b(a1,b,a,n);

}

C語(yǔ)言:數(shù)組函數(shù)問(wèn)題

二維數(shù)組這樣寫是不正確的。比如把s[]數(shù)組的數(shù)連接在a[]后面,直接是strcat(a,s),直接寫數(shù)組名。而在char strcat(char a[][],s[])中,第一個(gè)參數(shù)應(yīng)該寫為a[][50],第二個(gè)方括號(hào)里的不能省略。

c語(yǔ)言編程題 二維數(shù)組和函數(shù)

#include?stdio.h

#include?stdlib.h

#include?string.h

int?Input(long?number[],?int?score[][3])?{

int?i=0;

printf("Input?Score:?Number?Grad1?Grad2?Grad3\n");

while?(i30)?{

scanf("%ld?%d?%d?%d",?number[i],?score[i][0],?score[i][1],?score[i][2]);

if?(number[i]0)?break;

i++;

}

return?i;

}

void?Total1(int?score[][3],?float?sum[],?float?aver[],?int?n)?{

int?i;

for?(i=0;in;i++)?{

sum[i]?=?score[i][0]?+?score[i][1]?+?score[i][2];

aver[i]?=?sum[i]/3;

}

}

void?Total2(int?score[][3],?float?sum[],?float?aver[],?int?n)?{

int?i;

sum[0]?=?sum[1]?=?sum[2]?=?0.0f;

for?(i=0;in;i++)?{

sum[0]?+=?score[i][0];

sum[1]?+=?score[i][1];

sum[2]?+=?score[i][2];

}

for?(i=0;i3;i++)

aver[i]?=?sum[i]/3;

}

void?Total3(long?num[],int?score[][3],float?sum[],float?aver[],int?n)?{

int?i,?j;

long?_n;

int?_s;

float?_sum,?_ave;

Total1(score,?sum,?aver,?n);

for?(i=0;in-1;i++)?{

for?(j=n;ji;j--)?{

if?(sum[i]sum[j])?{

//swap?(i,?j)

_n?=?num[i];?num[i]?=?num[j];?num[j]?=?_n;

_s?=?score[i][0];score[i][0]?=?score[j][0];?score[j][0]?=?_s;

_s?=?score[i][1];score[i][1]?=?score[j][1];?score[j][1]?=?_s;

_s?=?score[i][2];score[i][2]?=?score[j][2];?score[j][2]?=?_s;

_sum?=?sum[i];?sum[i]?=?sum[j];?sum[j]?=?_sum;

_ave?=?aver[i];?aver[i]?=?aver[j];?aver[j]?=?_ave;

}

}

}

}

void?Print(long?num[],int?score[][3],float?sum1[],float?aver1[],float?sum2[],float?aver2[],int?n)?{

int?i;

printf("Pos\tNumber\tGrad1\tGrad2\tGrad3\tSum1\tAver1\n");

for?(i=0;in;i++)?{

printf("%d\t%ld\t%d\t%d\t%d\t%.1f\t%.1f\n",?(i+1),?num[i],?score[i][0],?score[i][1],?score[i][2],?sum1[i],?aver1[i]);

}

printf("No\tSum2\tAver2\n");

for?(i=0;i3;i++)?{

printf("%d\t%.1f\t%.1f\n",?(i+1),?sum2[i],?aver2[i]);

}

}

int?main()?{

long?number[30];

int?score[30][3];

float?sum1[30],?aver1[30];

float?sum2[30],?aver2[30];

float?sum3[3],?aver3[3];

int?n;

n?=?Input(number,?score);

Total1(score,?sum1,?aver1,?n);

Total2(score,?sum3,?aver3,?n);

Print(number,?score,?sum1,?aver1,?sum3,?aver3,?n);

Total3(number,?score,?sum2,?aver2,?n);

Print(number,?score,?sum2,?aver2,?sum3,?aver3,?n);

return?0;

}

關(guān)于C語(yǔ)言編程的兩道題,要用到數(shù)組,最好用到函數(shù)調(diào)用~

1

#include "stdio.h"

void main()

{

int a,b,c;

for(a=1;a=9;a++)

for(b=0;b=9;b++)

for(c=0;c=9;c++)

if(a*a*a+b*b*b+c*c*c==100*a+10*b+c)

printf("%d%d%d ",a,b,c);

}

2

#include "stdio.h"

#include "math.h"

void main()

{

int i;

float x,s=0;

for(i=0;i10;i++)

{

scanf("%f",x);

s+=sqrt(x);

}

printf("%f",s);

}

希望對(duì)你有幫助


網(wǎng)站欄目:c語(yǔ)言數(shù)組和函數(shù)面試題,c語(yǔ)言c++面試題
文章URL:http://weahome.cn/article/dssoihi.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部