閱讀以下程序說(shuō)明和C程序,將應(yīng)填入__(n)__ 處的字句,寫在答卷的對(duì)應(yīng)欄內(nèi)。
[程序說(shuō)明]
本程序中的函數(shù)factor( m,fac,cp )用來(lái)計(jì)算正整 m ( m > 2 )的除自身以外的所有不同因子的和。該函數(shù)返回因子和,并把各因子從小到大依次存放在數(shù)組 fac 中,其因子個(gè)數(shù)存入在 cp 所指的變量中。
例如 m=16,求得的因子為
(1,2,4,8)
提示:因子和為15,因子個(gè)數(shù)為4。
程序假定正整數(shù) m 的不同因子個(gè)數(shù)不會(huì)超過(guò)100個(gè)。
[程序]
# include
# define N 100
long factor (int m,int fac[],int *cp)
{
int c1, c2 , i, k;
long s;
fac[0] = 1;
for(c1 = s = 1,c2 = N-1,____(1)____;;)
{
k = m/i;
if (____(2)____)
if (____(3)____)
{ fac[c1++] = i;
fac[c2--] = k;
s + = i+k;
}
else {
fac[c1++] = i;
s + = i;
}
i++;
if(i>=k) brdak;
}
for (c2++;c2 <= N-1;c2++)
____(4)____;
*cp=c1;
return ____(5)____;
答案:
1)3分 i = 2,或 cl + 1
2)3分 m % i == 0 (或 !(m % i) 或 m == i * k )
3)3分 i ! = k (或 i < k )
4)3分 fac [ cl ++ ] = fac [ c2 ]
答 cl ++ 給 1 分,‘ = ’左右只對(duì)一半給 1 分。
5)3分 s
1.以下不是c語(yǔ)言規(guī)定保留字的是( )。
(1)float
(2)integer
(3)signed
(4) unsigned
2.設(shè)int型變量x有初始值3,則表達(dá)式x++*5/10的值是( )
(1)0
(2)1
(3)2
(4)3
3.下述程序執(zhí)行后的輸出結(jié)果是( )
#include
main()
{
int x=’f’;
printf("% %c\n",’a’+(x-’a’+1));
}
(1)G
(2)H
(3)I
(4)J
4.設(shè)有程序,整理!
#include
main()
{
int i,j;
for (i=0,j=1;i<=j+1;i+=2,j--)
printf("%d\n",i);
}
在運(yùn)行上述程序時(shí),for語(yǔ)句中循環(huán)體的執(zhí)行次數(shù)是( )
(1)3
(2)2
(3)1
(4)0
5.在下述選項(xiàng)時(shí),沒(méi)有構(gòu)成死循環(huán)的程序是( )
(1)int i=100
while (1)
{
i=i0+1;
if (i>100)
break;
}
(2)for (;;);
(3)int k=1000;
do
{
++k;
}while (k>=10000);
(4) int s=36;
while (s);--s;
答案:
1.(2) 2.(2) 3.(1) 4.(3) 5.(3)
1.假定a和b為int型變量,則執(zhí)行下述語(yǔ)句組后,b的值為( )。
a=1;
b=10;
do
{
b-=a;
a++;
} while (b--<0);
(1)9 (2)-2 (3)-1 (4)8
2.設(shè)有變量說(shuō)明語(yǔ)句
int a=1,b=0;
則執(zhí)行以下程序段的輸出結(jié)果為( )。
switch (a)
{
case 1:
switch (b)
{
case 0:printf("**0**");break;
case 1:printf("**1**");break;
}
case 2:printf("**2**");break;
}
printf("\n");
(1)**0** (2)**0****2** (3)**0****1****2** (4)有語(yǔ)法錯(cuò)誤
3.以下合法的數(shù)組說(shuō)明是( )。
(1)char a[6]="string";
(2)int a[5]={0,1,2,3,4,5};
(3)char a="string";
(4)INT a[]={0,12,3,4,5};
4.下述程序代碼中有語(yǔ)法錯(cuò)誤的行是( )。
int i,ia[10],ib[10]; /*第一行*/
for (i=0;i<
=9;i++) /*第2行*/
ia=0; /*第3行*/
ib=ia; /第4行*/
(1)第1行 (2)第2行 (3)第3行 (4)第4行
5.若已定義
int a[9],*p=a;
提示:在以后的語(yǔ)句中未改變p的值,則不能表示a[1]地址的表達(dá)式是( )。
(1)p+1 (2)a+1 (3)a++ (4)++p
答案:
1.(4) 2.(2) 3.(4) 4.(4) 5.(3)
相關(guān)推薦:計(jì)算機(jī)軟考程序員備考:程序設(shè)計(jì)知識(shí)點(diǎn)匯總北京 | 天津 | 上海 | 江蘇 | 山東 |
安徽 | 浙江 | 江西 | 福建 | 深圳 |
廣東 | 河北 | 湖南 | 廣西 | 河南 |
海南 | 湖北 | 四川 | 重慶 | 云南 |
貴州 | 西藏 | 新疆 | 陜西 | 山西 |
寧夏 | 甘肅 | 青海 | 遼寧 | 吉林 |
黑龍江 | 內(nèi)蒙古 |