生活随笔
收集整理的這篇文章主要介紹了
全国计算机等级考试题库二级C操作题100套(第06套)
小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.
第06套:
給定程序中,函數(shù)fun的功能是根據(jù)形參i的值返回某個(gè)函數(shù)的值。當(dāng)調(diào)用正確時(shí), 程序輸出:
x1=5.000000, x2=3.000000, x1x1+x1x2=40.000000
請?jiān)诔绦虻南聞澗€處填入正確的內(nèi)容并把下劃線刪除, 使程序得出正確的結(jié)果。
注意:源程序存放在考生文件夾下的BLANK1.C中。
不得增行或刪行,也不得更改程序的結(jié)構(gòu)!
給定源程序:
#include <stdio.h>
double f1(double x
)
{ return x
*x
; }
double f2(double x
, double y
)
{ return x
*y
; }
__1__
fun(int i
, double x
, double y
)
{ if (i
==1)
return __2__(x
);
else
return __3__(x
, y
);
}
main()
{ double x1
=5, x2
=3, r
;
r
= fun(1, x1
, x2
);
r
+= fun(2, x1
, x2
);
printf("\nx1=%f, x2=%f, x1*x1+x1*x2=%f\n\n",x1
, x2
, r
);
}
解題思路:
本題是根據(jù)給定的公式來計(jì)算函數(shù)的值。
第一處:程序中使用雙精度double類型進(jìn)行計(jì)算,所以函數(shù)的返回值類型也為double,所以應(yīng)填:double。
第二處:當(dāng)i等于1時(shí),則返回f1函數(shù)的值,所以應(yīng)填:f1。
第三處:如果i不等于1,則返回f2函數(shù)的值,所以應(yīng)填:f2。
給定程序MODI1.C中函數(shù)fun的功能是: 比較兩個(gè)字符串,將長的那個(gè)字符串的首地址作為函數(shù)值返回。
請改正函數(shù)fun中指定部位的錯(cuò)誤, 使它能得出正確的結(jié)果。
注意: 不要改動main函數(shù), 不得增行或刪行, 也不得更改程序的結(jié)構(gòu)!
給定源程序:
#include <stdio.h>
char fun(char *s
, char *t
)
{ int sl
=0,tl
=0; char *ss
, *tt
;
ss
=s
; tt
=t
;
while(*ss
)
{ sl
++; (*ss
)++;
}
while(*tt
)
{ tl
++; (*tt
)++;
}
if(tl
>sl
) return t
;
else return s
;
}
main()
{ char a
[80],b
[80],*p
,*q
; int i
;
printf("\nEnter a string : "); gets(a
);
printf("\nEnter a string again : "); gets(b
);
printf("\nThe longer is :\n\n\"%s\"\n",fun(a
,b
));
}
解題思路:
第一處: 試題要求返回字符串的首地址,所以應(yīng)改為:char *fun(char *s,char *t)
第二處: 取字符串指針ss的下一個(gè)位置,所以應(yīng)改為:ss++;。
第三處:取字符串指針tt的下一個(gè)位置,所以應(yīng)改為:tt++;。
請編寫函數(shù)fun,函數(shù)的功能是: 移動字符串中的內(nèi)容,移動的規(guī)則如下: 把第1到第m個(gè)字符, 平移到字符串的最后, 把第m+1到最后的字符移到字符串的前部。
例如, 字符串中原有的內(nèi)容為: ABCDEFGHIJK, m的值為3, 則移動后, 字符串中的內(nèi)容應(yīng)該是: DEFGHIJKABC。
注意:部分源程序在文件PROG1.C中。
請勿改動主函數(shù)main和其它函數(shù)中的任何內(nèi)容, 僅在函數(shù)fun的花括號中填入你編寫的若干語句。
給定源程序:
#include <stdio.h>
#include <string.h>
#define N 80
void fun1(char *w
)
{
int i
; char t
;
t
=w
[0];
for(i
=0;i
<strlen(w
)-1;i
++)
w
[i
]=w
[i
+1];
w
[strlen(w
)-1]=t
;
}
void fun(char *w
, int m
)
{
}
main()
{ char a
[N
]= "ABCDEFGHIJK";
int m
;
printf("The original string:\n");puts(a
);
printf("\n\nEnter m: ");scanf("%d",&m
);
fun(a
,m
);
printf("\nThe string after moving:\n");puts(a
);
printf("\n\n");
NONO();
}
解題思路:
本題是考察字符串的操作。
由于函數(shù)fun1是將字符串中字符循環(huán)左移一個(gè)位置,并通過實(shí)參w返回循環(huán)左移一個(gè)位置的字符串。利用循環(huán)for語句來操作多少個(gè)字符(m)需要循環(huán)左移。
參考答案:
void fun1(char *w
)
{
int i
; char t
;
t
=w
[0];
for(i
=0;i
<strlen(w
)-1;i
++)
w
[i
]=w
[i
+1];
w
[strlen(w
)-1]=t
;
}
void fun(char *w
, int m
)
{
int i
;
for(i
= 0 ; i
< m
; i
++) fun1(w
);
}
創(chuàng)作挑戰(zhàn)賽新人創(chuàng)作獎勵來咯,堅(jiān)持創(chuàng)作打卡瓜分現(xiàn)金大獎
總結(jié)
以上是生活随笔為你收集整理的全国计算机等级考试题库二级C操作题100套(第06套)的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
如果覺得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。