c语言国二考试编程题答案Word格式.doc
- 文档编号:13124085
- 上传时间:2022-10-06
- 格式:DOC
- 页数:65
- 大小:310.50KB
c语言国二考试编程题答案Word格式.doc
《c语言国二考试编程题答案Word格式.doc》由会员分享,可在线阅读,更多相关《c语言国二考试编程题答案Word格式.doc(65页珍藏版)》请在冰豆网上搜索。
{inti,n,below[9];
intscore[9]={10,20,30,40,50,60,70,80,90};
n=fun(score,9,below);
printf("
\nbelowtheaveragescoreare:
"
);
n;
i++)printf("
%4d"
below[i]);
2.请编写函数fun,它的功能是:
求出1到1000之内能被7或11整除、但不能同时被7和11整除的所有整数并将它们放在a所指的数组中,通过n返回这些数的个数。
该题关键就是如何表示能被7或11整除,但不能同时被7和11整除。
用(i%7==0)||(i%11==0)来表示能被7或11整除,用!
((i%7==0)&
&
(i%11==0))来表示不能同时被7和11整除。
voidfun(int*a,int*n)
{inti,m=0;
for(i=1;
1000;
i++)
if(((i%7==0)||(i%11==0))&
!
(i%11==0))){a[m]=i;
m+=1;
*n=m;
}
{intaa[1000],n,k;
clrscr();
fun(aa,&
n);
for(k=0;
k<
k++)
if((k+1)%10==0)printf("
\n"
elseprintf("
%d,"
aa[k]);
3.请编写函数voidfun(intx,intpp[],int*n),它的功能是:
求出能整除x且不是偶数的各整数,并按从小到大的顺序放在pp所指的数组中,这些除数的个数通过形参n返回。
例如,若x中的值为30,则有4个数符合要求,它们是1,3,5,15。
由于要求的数不能是偶数故编程时从1开始循环而步长为2这样正好保正i永远的奇数。
这里也要注意存放结果的数组pp的下标变化方式。
voidfun(intx,intpp[],int*n)
{inti,j=0;
for(i=1;
=x;
i=i+2)
if(x%i==0)pp[j++]=i;
*n=j;
}
{intx,aa[1000],n,i;
\npleaseenteranintegernumber:
scanf("
%d"
&
x);
fun(x,aa,&
%d"
aa[i]);
4.请编写一个函数voidfun(char*tt,intpp[]),统计在字符串中'
a'
到'
z'
26个字母各自出现的次数,并依次放在pp所指数组中。
例如,当输入字符串abcdefgabcdeabc后,程序的输出结果应该是:
33322110000000000000000000本题采用的是字母的ASCII码值与数组pp下标的对应转换关系分别求出对应字母的个数。
第一个for是给pp赋初值0,第二个for用于控制在字符串内从头到尾移动。
由于字母'
的ASCII码值为97而它的个数要放在pp[0]中,而'
-97的值正好为0。
voidfun(char*tt,intpp[])
{inti;
26;
i++)
pp[i]=0;
for(;
*tt;
tt++)
if(*tt<
='
&
*tt>
)pp[*tt-97]++;
}
{charaa[1000];
intbb[26],k;
clrscr();
\nPleaseenteracharstring:
%s"
aa);
fun(aa,bb);
for(k=0;
k++)printf("
bb[k]);
5.请编写一个函数voidfun(intm,intk,intxx[]),该函数的功能是:
将大于整数m且紧靠m的k个素数存入xx所指的数组中。
例如,若输入:
17,5,则应输出:
19,23,29,31,37。
本题中的for循环用来判断一个数是否为素数,由于个数只能是k个所以用do-while循环来控制。
voidfun(intm,intk,intxx[])
{inti,j=0,p=m+1;
do
{for(i=2;
p;
i++)
if(p%i==0)break;
if(i>
=p)xx[j++]=p;
p++;
}while(j<
k);
}
{intm,n,zz[1000];
\npleaseentertwointegers:
%d%d"
m,&
fun(m,n,zz);
for(m=0;
m<
m++)printf("
zz[m]);
6.请编写一个函数voidfun(chara[],charb[],intn),其功能是:
删除一个字符串中指定下标的字符。
其中,a指向原字符串,删除后的字符串存放在b所指的数组中,n中存放指定的下标。
例如,输入一个字符串World,然后输入3,则调用该函数后的结果为Word。
#defineLEN20
voidfun(chara[],charb[],intn)
{inti,k=0;
a[i]!
\0'
;
if(i!
=n)b[k++]=a[i];
b[k]='
main()
{FILE*wf;
charstrl[LEN],str2[LEN];
intn;
printf("
Enterthestring:
);
gets(strl);
Enterthepositiondeleted:
scanf("
fun(strl,str2,n);
Thenewstringis:
%s\n"
str2);
wf=fopen("
out.dat"
"
w"
fun("
world"
str2,3);
fprintf(wf,"
fclose(wf);
7.请编写一个函数intfun(int*s,intt,int*k),用来求出数组的最大元素在数组中的下标并存放在k所指的存储单元中。
例如,输入如下整数:
876675896101301401980431451777则输出结果为:
6,980。
intfun(int*s,intt,int*k)
{inti,max;
max=s[0];
for(i=0;
t;
i++)
if(s[i]>
max){max=s[i];
*k=i;
}
}
{inta[10]={876,675,896,101,301,401,980,431,451,777},k;
fun(a,10,&
%d,%d\n"
k,a[k]);
8.编写函数fun,函数的功能是:
根据以下公式计算s,计算结果作为函数值返回;
n通过形参传入。
s=1+1/(1+2)+1/(1+2+3)+.......+1/(1+2+3+4+......+n),例如:
若n的值为11时,函数的值为1.833333。
floatfun(intn)
{inti,sum=1;
floats=1;
for(i=2;
=n;
i++)
{sum=sum+i;
s=s+1.0/sum;
}
returns;
}
longchsdc(intn)
{inti,s;
s=0;
i++)s=s+i;
return(s);
{intn;
floats;
\nPleaseenterN:
s=fun(n);
theresultis:
%f\n"
s);
9.编写函数fun,它的功能是:
根据以下公式求P的值,结果由函数值带回。
m与n为两个正整数且要求m>
n。
p=m!
/n!
(m-n)!
。
例如:
m=12,n=8时,运行结果为495.000000。
floatfun(intm,intn)
{inti,j,k;
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 语言 考试 编程 答案 精品 文档
![提示](https://static.bdocx.com/images/bang_tan.gif)