南开一百题免费下载.docx
《南开一百题免费下载.docx》由会员分享,可在线阅读,更多相关《南开一百题免费下载.docx(111页珍藏版)》请在冰豆网上搜索。
南开一百题免费下载
06年南开上机题
1:
第1题m个人的成绩存放在score数组中,请编写函数fun,它的功能是:
将低于平均分的人作为函数值返回,将低于平均分的分数放在below所指定的函数中。
答案:
intfun(intscore[],intm,intbelow[])
{
inti,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++;
}
returnk;
}
#include"stdio.h"
#definen10
intfun(intscore[],intbelow[],intm)
{inti,p=0,j=0;
for(i=0;ip+=score[i];
p/=m;
for(i=0;iif(score[i]
returnj;
}
main()
{inti,num,score[n]={10,20,30,40,50,60,70,80,90,100},below[n];
for(i=0;iprintf("%-6d",score[i]);
num=fun(score,below,n);
printf("\nnum=%d\n",num);
for(i=0;iprintf("%-5d",below[i]);
printf("\n\n\n");
}
2:
第2题请编写函数fun,它的功能是:
求出1到100之内能北7或者11整除,但不能同时北7和11整除的所有证书,并将他们放在a所指的数组中,通过n返回这些数的个数。
答案:
voidfun(int*a,int*n)
{
inti,j=0;
for(i=2;i<1000;i++)
if((i%7==0||i%11==0)&&i%77!
=0)
a[j++]=i;
*n=j;
}
#include"stdio.h"
intfun(inta[])
{inti,j=0;
for(i=1;i<100;i++)
if((i%7==0&&i%11!
=0)||(i%7!
=0&&i%11==0))
a[j++]=i;
returnj;
}
main()
{inti,n,a[100];
n=fun(a);
printf("\n\n\nn=%d",n);
for(i=0;i{if(i%5==0)printf("\n");
printf("%-5d",a[i]);
}
}
3:
第3题请编写函数voidfun(intx,intpp[],int*n),它的功能是:
求出能整除x且不是偶数的各整数,并按从小到大的顺序放在pp所指的数组中,这些除数的个数通过形参n返回。
答案:
voidfun(intx,intpp[],int*n)
{
inti=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;
}
#include"stdio.h"
voidfun(intx,intpp[],int*n)
{inti,j=0;
for(i=1;i<=x;i++)
if(x%i==0&&i%2)pp[j++]=i;
*n=j;
}
main()
{inti,x,pp[20],n;
printf("\n\nx=");
scanf("%d",&x);
fun(x,pp,&n);
printf("\nn=%d\n",n);
for(i=0;iprintf("%-5d",pp[i]);
}_
4:
第4题请编写一个函数voidfun(char*tt,intpp[]),统计在tt字符中"a"到"z"26各字母各自出现的次数,并依次放在pp所指的数组中。
答案:
voidfun(char*tt,intpp[])
{
inti;
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;
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++;
}
}
#include"stdio.h"
#include"string.h"
voidfun(char*tt,intpp[])
{inti,j=0;
for(i=0;iif(tt[i]>='a'&&tt[i]<='z')pp[(tt[i]-'a')]++;
}
main()
{char*tt="abcdeasjfewjndsz";
inti,pp[26];
for(i=0;i<26;i++)
pp[i]=0;
puts(tt);
fun(tt,pp);
for(i=0;i<26;i++)
{if(i%5==0)printf("\n\n");
printf("%c:
%-6d",i+'a',pp[i]);
}
printf("\n\n");
}_
5:
第5题请编写一个函数voidfun(intm,intk,intxx[]),该函数的功能是:
将大于整数m且紧靠m的k各素数存入xx所指的数组中。
答案:
voidfun(intm,intk,intxx[])
{
intg=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;
}
}
}
#include"stdio.h"
voidfun(intm,intk,intxx[])
{inti,j,n=0;
for(i=m+1;n<=k;i++)
{for(j=2;j
if(i%j==0)break;
if(j>=i)xx[n++]=i;
}
}
main()
{inti,xx[100],m=10,k=5;
fun(m,k,xx);
printf("\n\nm=%d,k=%d\n",m,k);
for(i=0;iprintf("%-5d",xx[i]);
}_
6:
第6题请编写一个函数voidfun(chara[],char[],intn),其功能是:
删除以各字符串中指定下标的字符。
其中,a指向原字符串,删除后的字符串存放在b所指的数组中,n中存放指定的下标。
答案:
voidfun(chara[],charb[],intn)
{
intI,j=0;
for(i=0;i<LEN;i++)
if(i!
=n)
{
b[j]=a[i];
j++;
}
b[j]=‘\0’;
}
#include"stdio.h"
#include"string.h"
voidfun(chara[],charb[],intn)
{inti,j=0;
for(i=0;iif(i!
=n)b[j++]=a[i];
b[j]='\0';
}
main()
{char*a="abcdefg",b[20];
intn;
puts(a);
printf("\n\n\nn=");
scanf("%d",&n);
while(n<0||n>=strlen(a)){printf("NO,n=");scanf("%d",&n);}
fun(a,b,n);
puts(b);
}
7:
第7题请编写一个函数intfun(int*s,intt,int*k),用来求除数组的最大元素在数组中的下标并存放在k所指的储存单元中。
答案:
voidfun(int*s,intt,int*k)
{
intI,max;
max=s[0];
for(i=0;i<t;i++)
if(s[i]>max)
{
max=s[i];
*k=I;
}
}
#include"stdio.h"
intfun(int*s,intt,int*k)
{inti,m=s[0];
*k=0;
for(i=0;iif(m
}
main()
{ints[6]={87,34,90,43,454,45},i,k;
for(i=0;i<6;i++)
printf("%5d",s[i]);
fun(s,6,&k);
printf("\nk=%d\n\n",k);
}_
8:
第8题编写函数fun,功能是:
根据以下攻势计算s,计算结果作为函数值返回;n通过形参传入。
S=1+1/(1+2)+1/(1+2+3)+…….+1/(1+2+3+4+……+n)
答
floatfun(intn)
{
inti;
floats=1.0,t=1.0;
for(i=2;i<=n;i++)
{
t=t+i;
s=s+1/t;
}
returns;
}
#include
doublefun(intn)
{inti,t=0;
doublep,s=0.0;
for(i=1;i<=n;i++)
{t+=i;
p=1.0/t;
s=s+p;
}
returns;
}
main()
{intn;
doubles;
printf("\nn=");
scanf("%d",&n);
s=fun(n);
printf("\ns=%lf\n\n",s);
}
9:
第9题编写一个函数fun,它的功能是:
根据以下公式求p的值,结果由函数值带回。
M与n为两个正整数,且要求m>n。
p=m!
/n!
(m-n)!
答案:
floatfun(intm,intn)
{
floatp,t=1.0;
intI;
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;
returnp;
}
#include"stdio.h"
doublefun(intm,intn)
{doublei,j,k=1.0,d=1.0,p;
for(i=1;i<=m;i++)
k*=i;
for(j=1;j<=n;j++)
d*=j;
for(i=1;i<=m-n;i++)
d*=i;
returnk/d;
}
main()
{intm,n;
doublep;
printf("mandn");
scanf("%d%d",&m,&n);
p=fun(m,n);
printf("\n%lf\n\n",p);
}
10:
第10题编写函数fun,它的功能是:
利用以下的简单迭代方法求方程cos(x)-x=0的一个实根。
迭代步骤如下:
(1)取x1初值为0.0;
(2)x0=x1,把x1的值赋各x0;
(3)x1=cos(x0),求出一个新的x1;
(4)若x0-x1的绝对值小于0.000001,则执行步骤(5),否则执行步骤
(2);
(5)所求x1就是方程cos(x)-x=0的一个实根,作为函数值返回。
程序将输出root=0.739085。
答案:
floatfun()
{
floatx1=0.0,x0;
do
{
x0=x1;
x1=cos(x0);
}
while(fabs(x0-x1)>1e-6);
returnx1;
}
#include"stdio.h"
#include"math.h"
floatfun()
{floatx1=0.0,x0;
do
{x0=x1;
x1=cos(x0);
}
while(fabs(x0-x1)>=1e-6);
returnx1;
}
main()
{printf("\n%f\n",fun());}
11:
第11题下列程序定义了n×n的二维数组,并在主函数中自动赋值。
请编写函数fun(inta[][n]),该函数的功能是:
使数组左下半三角元素中的值全部置成0。
答案:
intfun(inta[][N])
{
intI,j;
for(i=0;i<N;i++)
for(j=0;j<=I;j++)
a[i][j]=0;
}
#include"stdio.h"
#defineN4
voidfun(inta[][N])
{inti,j;
for(i=0;ifor(j=0;j<=i;j++)
a[i][j]=0;
}
main()
{inti,j,a[N][N];
for(i=0;i{for(j=0;jprintf("%-5d",a[i][j]=rand()%100);
printf("\n");
}
fun(a);
printf("\n");
for(i=0;i{for(j=0;jprintf("%-5d",a[i][j]);
printf("\n");
}printf("\n\n");
}
12:
第12题下列程序定义了n×n的二维数组,并在主函数中赋值。
请编写函数fun,函数的功能使求出数组周边元素的平均值并作为函数值返回给主函数中的s。
答案:
doublefun(intw[][N])
{
intI,j,k=0;
doubles=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++;
}
returns/=k;
}
#include"stdio.h"
#defineN3
doublefun(inta[N][N])
{inti,j,k=0;
doubles=0.0;
for(i=0;i{s+=a[0][i]+a[N-1][i];k+=2;}
for(j=1;j{s+=a[j][0]+a[j][N-1];k+=2;}
returns/=k;
}
main()
{inti,j,a[N][N]={20,20,30,45,50,60,70,80,20};
doubles;
for(i=0;i{for(j=0;jprintf("%-5d",a[i][j]);
printf("\n");
}
s=fun(a);
printf("\ns=%lf\n\n",s);
}
_
13:
第13题请编写一个函数voidfun(inttt[m][n],intpp[n]),tt指向一个m行n列的二维函数组,求出二维函数组每列中最小元素,并依次放入pp所指定一维数组中。
二维数组中的数已在主函数中赋予。
答案:
voidfun(inttt[M][N],intpp[N])
{
intI,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;
}
}
#include"stdio.h"
#defineM3
#defineN4
voidfun(inttt[M][N],intpp[N])
{inti,j,t,m=0;
for(i=0;i{t=tt[0][i];
for(j=0;jif(t>tt[j][i])t=tt[j][i];
pp[m++]=t;
}
}
main()
{inti,j,tt[M][N],pp[N];
for(i=0;i{for(j=0;jprintf("%-5d",tt[i][j]=rand()%100);
printf("\n");
}
fun(tt,pp);
printf("\n");
for(i=0;iprintf("%-5d",pp[i]);
printf("\n\n");
}_
14:
第14题请别写函数fun,函数的功能使求出二维数组周边元素之和,作为函数值返回。
二维数组中的值在主函数中赋予。
答案:
intfun(inta[M][N])
{
intI,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];
}
returns;
}
#include"stdio.h"
#defineM3
#defineN4
intfun(inta[M][N])
{inti,j,m=0;
for(j=0;j{m+=a[0][j];m+=a[M-1][j];}
for(i=1;i<=M-2;i++)
{m+=a[i][0];m+=a[i][N-1];}
returnm;
}
main()
{inta[M][N]/*={1,2,3,4,5,6,7,8,9,10,11,12}*/,i,j,m;
for(i=0;i{for(j=0;jprintf("%-5d",a[i][j]=rand()%10);
printf("\n");
}
m=fun(a);
printf("m=%d\n\n",m);
}_
15:
第15题请编写一个函数unsignedfun(unsignedw),w使一个大于10的无符号整数,若w使n(n≥2)位的整数,则函数求出w后n-1位的数作为函数值返回。
答案:
unsignedfun(unsignedw)
{
unsignedt,s=0,s1=1,p=0;
t=w;
while(t>10)
{
if(t/10)
p=t%10;
s=s+p*s1;
s1=s1*10;
t=t/10;
}
returns;
}
#include"stdio.h"
#definen4
unsignedfun(unsignedw)
{unsignedt,s=0,m=1,p=0;
t=w;
while(t>10)
{if(t/10)
s+=t%10*m;
m=m*10;
t=t/10;
}
returns;
}
main()
{unsignedw;
printf("w=");
scanf("%u",&w);
printf("%u\n\n",fun(w));
}_
16:
第16题请编写一个函数floatfun(doubleh),函数的功能使对变量h中的值保留2位小树,并对第三位进行四舍五入(规定h中的值位正数)。
答案:
floatfun(floath)
{
longt;
floats;
h=h*1000;
t=(h+5)/10;
s=(float)t/100.0;
returns;
}
#include"stdio.h"
floatfun(doubleh)
{longj;
floats;
h=h*1000;
j=(h+5)/10;
s=(float)(j/100.0);
returns;
}
main()
{floath;
printf("\nh=");
scanf("%f",&h);
printf("\n%.2f\n\n",fun(h));
}
17:
第17题请编写一个函数fun(char*s),该函数的功能使把字符串中的内容拟置。
答案
v