C语言程序设计形成性作业二Word格式文档下载.docx
- 文档编号:20065027
- 上传时间:2023-01-16
- 格式:DOCX
- 页数:10
- 大小:17.34KB
C语言程序设计形成性作业二Word格式文档下载.docx
《C语言程序设计形成性作业二Word格式文档下载.docx》由会员分享,可在线阅读,更多相关《C语言程序设计形成性作业二Word格式文档下载.docx(10页珍藏版)》请在冰豆网上搜索。
4.假定二维数组的定义为“chara[M][N];
”,则该数组所所含元素的个数为__M*N_____。
5.假定二维数组的定义为“doublea[M][N];
”,则每个数组元素的行下标取值范围在__0~M-1___之间。
6.假定二维数组的定义为“doublea[M][N];
”,则每个数组元素的列下标取值范围在__0~N-1___之间。
7.使用“typedefcharBB[10][50];
”语句定义__BB______为含有10行50列的二维字符数组类型。
8.存储字符’a’需要占用存储器的_1_____个字节空间。
9.空字符串的长度为__0_______。
10.存储一个空字符串需要占用__1___个字节。
11.字符串”a:
\\xxk\\数据”的长度为___11______。
12.用于存储一个长度为n的字符串的字符数组的长度至少为__n+1______。
13.strcmp函数用于进行两个字符串之间的___大小比较___。
14.Strcpy函数用于把一个字符串___复制到___另一个字符数组空间中。
15.一个二维字符数组a[10][20]能够存储__10___个字符串。
16.一个二维字符数组a[10][20]能够存储的每个字符串的长度至多为___19___.
三、写出下列每个程序运行后的输出结果
1.#include<
stdio.h>
voidmain()
{
inta[10]={12,39,26,41,55,63,72,40,83,95};
inti,i1=0,i2=0;
for(i=0;
i<
10;
i++)
if(a[i]%2==1)i1++;
elsei2++;
printf("
%d%d\n"
i1,i2);
}
输出结果为:
64
Pressanykeytocontinue
2.#include<
#include<
string.h>
inti;
char*a[5]={"
student"
"
worker"
cadre"
soldier"
peasant"
};
char*p1,*p2;
p1=p2=a[0];
5;
i++){
if(strcmp(a[i],p1)>
0)p1=a[i];
if(strcmp(a[i],p2)<
0)p2=a[i];
}
printf("
%s%s\n"
p1,p2);
workercadre
3.#include<
inta[10]={4,5,6,15,20,13,12,7,8,9};
inti,s0,s1,s2;
s0=s1=s2=0;
switch(a[i]%3){
case0:
s0+=a[i];
break;
case1:
s1+=a[i];
case2:
s2+=a[i];
}
%d%d%d\n"
s0,s1,s2);
422433
4.#include<
chara[]="
abcdbfbgacd"
;
inti1=0,i2=0,i=0;
while(a[i]){
if(a[i]=='
a'
)i1++;
b'
)i2++;
i++;
i1,i2,i);
2311
5.#include<
inta[3][4]={{1,2,7,8},{5,6,10,6},{9,12,3,4}};
intm=a[0][0];
intii=0,jj=0;
inti,j;
3;
for(j=0;
j<
4;
j++)
if(a[i][j]>
m){m=a[i][j];
ii=i;
jj=j;
ii,jj,a[ii][jj]);
2112
6.#include<
inta,b;
for(a=1,b=2;
b<
50;
){
%d%d"
a,b);
a=a+b;
b=a+b;
\n"
);
12358132134
四、写出下列每个函数的功能
intSA(inta,intb){
if(a>
b)return1;
elseif(a==b)return0;
elsereturn-1;
函数功能为:
根据实参a大于、等于或小于实参b,返回1,0或-1
intSC(inta,intb,intc){
=b&
&
a>
=c)returna;
if(b>
=a&
b>
=c)returnb;
returnc;
返回实参a、b、c中的最大数
3.doubleSF(doublex,intn){//n为大于等于0的整数
doublep=1,s=1;
for(i=1;
=n;
p*=x;
s+=p/(i+1);
returns;
计算x+x2/2+x3/3+……+xn/(n+1)的值
math.h>
intSC(intx){
inta=(int)sqrt(x);
inti=2;
while(i<
=a){
if(x%i==0)break;
if(i<
=0)return0;
elsereturn1;
判断一个整数是否是素数
voidtrans(intx)
chara[10];
inti=0,rem;
do{
rem=x%16;
x=x/16;
if(rem<
10)a[i]=48+rem;
//'
0'
字符的ASCII码为48
elsea[i]=65+rem;
//'
A'
字符的ASCII码为65
}while(x!
=0);
while(i>
0)printf("
%c"
a[--i]);
将一个整数化成十六进制数
五、根据下列每个题目要求编写程序
1.编写一个函数,函数头格式为“voidfun4(char*a,intb[])”,分别求出由字符指针a所指向的字符串中包含的每种十进制数字出现的次数,把统计结果保存在数组b的相应元素中。
voidfun4(char*a,intb[]){
if(*a>
='
&
*a<
9'
)b[*a-48]++;
}while(*a++);
/*voidmain()
char*a="
122333444499888"
intb[10]={0};
fun4(a,b);
for(inti=0;
%d"
b[i]);
}*/
2.编写一个函数,函数头格式为“doubleMean(doublea[M][N],intm,intn)”,要求返回二维数组a[m][n]中所有元素的平均值,假定在计算过程是采用变量v存放平均值。
constintM=2,N=3;
doubleMean(doublea[M][N],intm,intn){
doublev=0;
m;
for(intj=0;
n;
v+=a[i][j];
returnv/(m*n);
doublea[2][3]={1,2,3,4,5,6};
%lf\n"
Mean(a,2,3));
3.编写一个递归函数“intFF(inta[],intn)”,求出数组a中所有元素n个元素之积并返回。
intFF(inta[],intn){
intmul=1;
if(n==1)mul*=a[0];
elsemul=a[n-1]*FF(a,n-1);
returnmul;
inta[6]={1,2,3,4,5,6};
%d\n"
FF(a,6));
4.
编写一个主函数,利用while循环,求出并显示满足不等式1+1/2+1/3+……+1/n>
5的最小n值。
doublesum=0;
intn=1;
while(true)
{
if(sum+1/(double)n>
5)break;
else
sum+=1/(double)n;
n++;
%d,%lf\n"
n,sum);
5.编写一个主函数,求满足不等式22+42+……+n2<
1000的最大n值,假定分别用i和s作为取偶数值和累加值的变量,并限定使用do循环编程。
ints=0,i=2;
do
s+=i*i;
if(s+(i+2)*(i+2)>
=1000)break;
elsei+=2;
}while(true);
i=%d,s=%d"
i,s);
6.编写一个主函数,计算并输出12+22+……+n2值,其中n值由键盘输入。
ints=0,n;
请输入n的值:
"
scanf("
%d"
&
n);
for(inti=1;
n=%d,s=%d"
n,s);
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 语言程序设计 形成 作业