二 填空題
1.下列程序的輸出結(jié)果是 5 6 。
int t(int x, int y, int cp, int dp)
{cp=x*x+y*y;
dp=x*x-y*y;
}
main( )
{int a=4, b=3, c=5, d=6;
t(a, b, c, D);
printf("%d %d\n", c, D);
}
2.以下程序的運(yùn)行結(jié)果是 8,17 。
#include
main()
{int k=4, m=1, p;
p=func(k, m); printf("%d,", p);
p=func(k, m); printf("%d\n", p);
}
func(int a, int B)
{static int m=0, i=2;
i+=m+1;
m=i+a+b;
return m;
}
3.以下程序輸出的最后一個(gè)值是 120 。
int ff(int n)
{static int f=l;
f=f*n;
return f;
}
main()
{int i;
for(i=1;i<=5;i++) printf("%d\n",ff(i));
}
4.以下函數(shù)的功能是:求x的y次方,請(qǐng)?zhí)羁铡?/P>
double fun(double x, int y)
{int i;
double z;
for(i=1, z=x; i return z; } 5.若變量n中的值為24,則prnt函數(shù)共輸出 5 行,最后一行有 4 個(gè)數(shù)。 void prnt(int n, int aa[ ]) {int i; for(i=1; i<=n; i++) {printf("%6d", aa[i]); if(!(i%5)) printf("\n"); } printf("\n"); } 6.以下程序中,主函數(shù)調(diào)用了LineMax函數(shù),實(shí)現(xiàn)在N行M列的二維數(shù)組中,找出每一行上的最大值。請(qǐng)?zhí)羁铡?/P>
#define N 3 #define M 4 void LineMax(int x[N][M]) {int i, j, p; for(i=0; i {p=0; for(j=1; j if(x[i][p] printf("The max value in line %d is %d\n", i, x[i][p] ); } } main() {int x[N][M]={1,5,7,4,2,6,4,3,8,2,3,1}; LineMax(x) } 7.函數(shù)pi的功能是根據(jù)以下近似公式求π值: (π*π)/6=1+1/(2*2)+1/(3*3)+ … +1/(n*n) 請(qǐng)?jiān)谙旅娴暮瘮?shù)中填空,完成求π的功能。 #include “math.h” double pi(long n) {double s=0.0; long i; for(i=1;i<=n; i++) s=s+ 1.0/i*i ; return(sqrt(6*s)); } 8.設(shè)在主函數(shù)中有以下定義和函數(shù)調(diào)用語(yǔ)句,且fun函數(shù)為void類(lèi)型;請(qǐng)寫(xiě)出fun函數(shù)的首部 void fun( double b[10][22]) 。要求形參名為b。 main() {double s[10][22]; int n; … fun(s); … } 9.輸入12時(shí),程序輸出結(jié)果為 12 is not prime number. ;若輸入17,輸出結(jié)果為 17 is prime number. 。 main() {int number; scanf(“%d”, &number); if(prime(number)) printf(“\n%d is prime number.”, number); else printf(“\n%d is not prime number.”, number); } int prime(int number) {int flag=1, n; for(n=2; n if(number%n= =0) flag=0; return(flag); } 10.理解下面的程序,填空完善程序。 main() {int a, b, c; scanf(“%d %d”, &a,%b ); c= max (a, B); printf(“a=%d b=%d max=%d\n”, a, b, C); } int max(x, y) int x,int y ; {int z; if(x>y) z=x; else z=y; return z ; } 11.下面程序的輸出結(jié)果是 2,5,1,2,3,-2 。 main() {int a=3, b=2, c=1; c-=++b; b*=a+c; {int b=5, c=12; c/=b*2; a-=c; printf(“%d, %d, %d,”, a, b, C); a+=--c; } printf(“%d, %d, %d”, a, b, C); } 12.下面的findmax函數(shù)返回?cái)?shù)組s中值為最大的元素的下標(biāo),數(shù)組中元素的個(gè)數(shù)由t傳人,請(qǐng)?zhí)羁铡?/P>
findmax(int s[ ], int t) {int k, p; for(p=0, k=p; p if(s[p]>s[k]) p=k ; return k; } 13.下面程序的輸出結(jié)果是 7 。 fun(int x) {int p; if(x= =0||x= =1) return(3); p=x-fun(x-2); return p; } main() {printf(“%d\n”, fun(9));} 14.函數(shù)fun的功能是:使一個(gè)字符串按逆序存放,請(qǐng)?zhí)羁铡?/P>
void fun(char str[ ]) {char m; int i, j; for(i=0, j=strlen(str); i< strlen(str) ; i++, j--) {m=str[i]; str[i]= str[j-1] ; str[j-1]=m; } printf(“%s\n”, str); }
北京 | 天津 | 上海 | 江蘇 | 山東 |
安徽 | 浙江 | 江西 | 福建 | 深圳 |
廣東 | 河北 | 湖南 | 廣西 | 河南 |
海南 | 湖北 | 四川 | 重慶 | 云南 |
貴州 | 西藏 | 新疆 | 陜西 | 山西 |
寧夏 | 甘肅 | 青海 | 遼寧 | 吉林 |
黑龍江 | 內(nèi)蒙古 |