是:最外层元素的值全部为1;从外向内第2层元素的值全部为2;第3层元素的值全部为3,…依次类推。例如,若N=5,生成的矩阵为:
1 1 1 1 1
1 2 2 2 1
1 2 3 2 1
1 2 2 2 1
1 1 1 1 1
请在程序的下划线处填入正确的内容并把下划线删除, 使程序得出正确的结果。
注意:源程序存放在考生文件夹下BLANK1.C中。
不得增行或删行,也不得更改程序的结构!
给定源程序:
#include
#define N 7
/**********found**********/
void fun(int (*a) [N])
{int i,j,k,m;
if(N%2==0) m=N/2 ;
else m=N/2+1;
for(i=0; i /**********found**********/ for(j= i ; j a[i][j]=a[N-i-1][j]=i+1; for(k=i+1; k /**********found**********/ a[k][i]=a[k][N-i-1]= i+1; } } main() {int x[N][N]={0},i,j; fun(x); printf("\nThe result is:\n"); for(i=0; i {for(j=0; j printf("\n"); } } 解题答案: /**********第一空**********/ void fun(int (*a) [N]) /**********第二空**********/ for(j= i ; j /**********第三空**********/ a[k][i]=a[k][N-i-1]= i+1; ****************************************** [NextPage] 二、改错题:给定程序MODI1.C中函数 fun 的功能是: 将十进制正整数m转换成k(2≤k≤9) 进制数, 并按高位到低位顺序输出。 例如,若输入8和2,则应输出1000(即十进制数8转换成二进制表示是1000)。 请改正 fun 函数中的错误,使它能得出正确的结果。 注意:不要改动 main 函数。不得增行或删行,也不得更改程序的结构! 给定源程序: #include #include void fun(int m, int k) { int aa[20], i; for(i = 0; m; i++) { /**********found**********/ aa[i] = m/k; m /= k; } for(; i; i--) /**********found**********/ printf("%d", aa[i]); } main() { int b, n; printf("\nPlease enter a number and a base:\n"); scanf("%d %d", &n, &b); fun(n, b); printf("\n"); } 解题答案: /**********found**********/ aa[i]=m%k; /**********found**********/ printf("%d", aa[i-1]); ****************************************** [NextPage] 三、程序题:编写一个函数,从num个字符串中找出最长的一个字符串,并通过形参指针max传回该串地址。(注意: 主函数中用****作为结束输入的标志,函数fun中给出的语句仅供参考。) 注意:部分源程序在文件PROG1.C中。 请勿改动主函数main和其它函数中的任何内容,仅在函数fun的花括号中填入你编写的若干语句。 给定源程序: #include #include void fun(char(*a)[81],int num,char **max) { } main() { char ss[10][81],*ps;void NONO (); int n,i=0; printf("输入若干个字符串:"); gets(ss[i]); puts(ss[i]); while(!strcmp(ss[i],"****")==0) { i++; gets(ss[i]); puts(ss[i]); } n=i; fun(ss,n,&ps); printf("\nmax=%s\n",ps); NONO(); } void NONO () { /* 请在此函数内打开文件,输入测试数据,调用 fun 函数,输出数据,关闭文件。 */ char ss[20][81],*ps; int n,i=0; FILE *rf, *wf ; rf = fopen("in.dat","r"); wf = fopen("out.dat","w"); fgets(ss[i], 81, rf); while(!strncmp(ss[i],"****",4)==0) { i++; fgets(ss[i], 81, rf); } n=i; fun(ss,n,&ps); fprintf(wf, "%s",ps); fclose(rf); fclose(wf); } 参考答案: fun(char(*a)[81],int num,char **max) { /* 以下代码仅供参考 */ int i,k=0,maxlen; /* k为a数组中最长串所在元素的下标,初始为0,maxlen为其串长 */ maxlen=strlen(a[k]); for(i=1;i { /* 以下完成查找最长串 */ if(strlen(a[i]) > maxlen) { maxlen = strlen(a[i]) ; k = i ; } } *max=a[k]; }
| 广告合作:400-664-0084 全国热线:400-664-0084 Copyright 2010 - 2017 www.my8848.com 珠峰网 粤ICP备15066211号 珠峰网 版权所有 All Rights Reserved
|