二、填空題:
(1)以下程序運(yùn)行后的輸出結(jié)果是 【1】 。
int f(int a[], int n)
{ if (n >= 1) return f(a, n-1)+a[n-1];
else return 0;
}
main()
{ int aa[5]={1,2,3,4,5}, s;
s=f(aa, 5); printf("%d\n", s);
}
(2) 下面程序的運(yùn)行結(jié)果是:【2】
int f( int a[], int n)
{ if(n>1) return a[0]+f(&a[1],n-1);
else return a[0];
}
main ( )
{ int aa[3]={1,2,3},s;
s=f(&aa[0],3); printf(“%d\n”,s);
}
(3) 以下程序運(yùn)行后的輸出結(jié)果是 【3】
fun(int x)
{ if (x/2>0) fun(x/2);
printf("%d",x);
}
main()
{ fun (6); }
(4) 設(shè)函數(shù)findbig已定義為求3個數(shù)中的最大值。以下程序?qū)⒗煤瘮?shù)指針調(diào)用findbig函數(shù)。請?zhí)羁铡?BR>main()
{ int findbig(int,int,int);
int (*f)(),x,yz,z,big;
f=【4】;
scanf("%d%d%d",&x,&y,&z);
big=(*f)(x,y,z);
printf("bing=%d\n",big);
}
(5) 以下程序的輸出結(jié)果是【5】 。
main()
{ int x=0;
sub(&x,8,1);
printf("%d\n",x);
}
sub(int *a,int n,int k)
{ if(k<=n) sub(a,n/2,2*k);
*a+=k;
}
(6) 以下程序的輸出結(jié)果是 【6】 。
fun(int n,int *s)
{ int f1,f2;
if(n = =1||n = =2) *s=1;
else { fun(n-1,&f1); fun(n-2,&f2); *s=f1+f2;} }
main()
{ int x;
fun(6,&x); printf("%d\n",x); }
(7) 下面程序的輸出是【7】 。
long fun5(int n)
{ long s;
if((n==1)||(n==2))
s=2;
else
s=n+fun5(n-1);
return(s);}
main()
{ long x;
x=fun5(4);
printf("%ld\n",x);}
double fgh(double( *f)(double a)< double( *g)(double b),
double x, double y)
{ return(【8】 );}
double h(double a, double b)
return(fgh( sin,cos,a,b)*fgh( 【9】] )); }
(9) 請讀程序:
#include<stdio.h>
main( int argc, char *argv[])
{ int i;
printf( '%d\n", argc);
for( i=0; i<=argc+1; i++) printf( "%s ", argv[i]);
printf("\n");
}
若上面的程序編譯、連接后生成可執(zhí)行文件ABC.EXE,則輸入以下命令行
abc file1 file2<CR>(<CR>表示回車)
程序執(zhí)行后的輸出結(jié)果是 【10】 。
(10) 下面程序的輸出結(jié)果是 【11】 。
#include <stdio.h>
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));}
北京 | 天津 | 上海 | 江蘇 | 山東 |
安徽 | 浙江 | 江西 | 福建 | 深圳 |
廣東 | 河北 | 湖南 | 廣西 | 河南 |
海南 | 湖北 | 四川 | 重慶 | 云南 |
貴州 | 西藏 | 新疆 | 陜西 | 山西 |
寧夏 | 甘肅 | 青海 | 遼寧 | 吉林 |
黑龍江 | 內(nèi)蒙古 |