填空题
程序的功能是计算s= 。
注意:部分源程序给出如下
请勿改动主函数main和其他函数中的任何内容,仅在横线上填入所编写的若干表达式或语句。
试题程序:
#include
long fun(int n)
{
int i;
long s;
s = ___1___;
for (i=1; i<=n; i++)
s = ___2___;
return s;
}
main()
{
long s;
int k, n;
scanf("%d", &n);
s = ___3___;
for (k=0; k<=n; k++)
s = ___4___;
printf("%ld\n", s);
}
第1处填空:1
第2处填空:s*i或i*s
第3处填空:0
第4处填空:s+fun(k)或fun(k)+s
改错题
在字符串的最前端加入n个*号,形成新串,
注意:字符串的长度允许为79。
请改正程序中的错误,使其能得出正确结果。
注意:不要改动main函数,不得增行或删行,也不得更改程序的结构!
试题程序:
#include
#include
#include
void fun(char s[], int n)
{
char a[80], *p;
int i;
/********found********/
s = p;
for (i=0; i
a[i] = '*';
do
{
a[i] = *p;
i++;
/********found********/
___ì???___
} while (*p);
/********found********/
a[i] = '0';
strcpy(s, a);
}
main()
{
int n;
char s[80];
printf("\nEnter a string :");
gets(s);
printf("\nThe string %s\n", s);
printf("\nEnter n(number of *): ");
scanf("%d", &n);
fun(s, n);
printf("\nThe string after inster: %s\n", s);
}
第1处:s=p;应改为p=s;
第2处:应填p++;或++p;或p+=1或p=p+1
第3处:a[i]=’0’;应改为a[i]=’\0’;或a[i]=0;
编程题
编写函数fun,它的功能是:
找出一维整数型数组元素中最大的值和它所在的下标,最大值和它的下标通过形参传回。数组元素中的值已在主函数中赋予,
主函数中x是数组名,n 是x 中的数据个数,max存放最大值,index中存放最大值所在元素的下标。
注意:部分源程序给出如下。
请勿改动主函数main和其他函数中的任何内容,仅在函数fun的花括号中填入所编写的若干语句。
试题程序:
#include
#include
#include
void fun ( int a[], int n, int *max, int *d )
{
}
main()
{
int i, x[20], max, index, n=10;
FILE *out;
for (i=0; i < n; i++)
{
x[i] = rand()%50;
printf("%4d", x[i]) ;
}
printf("\n");
fun( x, n , &max, &index);
printf("Max=%5d, Index=%4d\n", max, index);
out=fopen("out.dat", "w");
memcpy(x, "3.141592653589793238462643383279", 32);
fun( x, 8 , &max, &index);
fprintf(out, "Max=%5d, Index=%4d", max, index);
fclose(out);
}
答案是:
void fun(int a[], int n,int *max, int *d)
{
int i;
*max=a[0];
*d=0;
for(i=0;i
if(a[i]>*max)
{
*max=a[i];
*d=I;
}
}
北京 | 天津 | 上海 | 江苏 | 山东 |
安徽 | 浙江 | 江西 | 福建 | 深圳 |
广东 | 河北 | 湖南 | 广西 | 河南 |
海南 | 湖北 | 四川 | 重庆 | 云南 |
贵州 | 西藏 | 新疆 | 陕西 | 山西 |
宁夏 | 甘肃 | 青海 | 辽宁 | 吉林 |
黑龙江 | 内蒙古 |