知ing

最新计算机二级C语言上机试题汇编100套

NCRE研究组 编 / 高等教育出版社

゛Zirro、Y 上传

查看本书

35套: 

给定程序中,函数fun的功能是建立一个N×N的矩阵。 矩阵元素的构成规律是:最外层元素的值全部为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 <stdio.h> 

#define N 7 

/ **********found**********/ 

void fun(int (*a) __1__) 

{ int i,j,k,m; 

if(N%2==0) m=N/2 ; 

else m=N/2+1; 

for(i=0; i<m; i++) { 

/ **********found**********/ 

for(j= __2__ ; j<N-i; j++) 

a[i][j]=a[N-i-1][j]=i+1; 

for(k=i+1; k<N-i; k++) 

/ **********found**********/ 

a[k][i]=a[k][N-i-1]= __3__; 

main() 

 

{ int x[N][N]={0},i,j; 

fun(x); 

printf("\nThe result is:\n"); 

for(i=0; i<N; i++) 

{ for(j=0; j<N; j++) printf("%3d",x[i][j]); 

printf("\n"); 

解题思路: 

第一处:建立一个N×N的矩阵,所以应填:[N]。 

第二处:j的起始变量值应i。 

第三处:也应该填写i+1。 

*************************************************** 

给定程序MODI1.C中函数 fun 的功能是将十进制正整数m转换成k(2k9) 

进制数并按高位到低位顺序输出。 

例如,若输入82,则应输出1000(即十进制数8转换成二进制表示是1000)。 

请改正 fun 函数中的错误,使它能得出正确的结果。 

注意:不要改动 main 函数。不得增行或删行,也不得更改程序的结构! 

给定源程序: 

#include <conio.h> 

#include <stdio.h> 

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"); 

解题思路: 

第一处:应该取模而不是整除,所以应为:aa[i]=m%k;。 

第二处:输出aa的位置不正确,所以应为:printf("%d",aa[i-1]);。 

*************************************************** 

编写一个函数,num个字符串中找出最长的一个字符串,并通过形参指针max传回该串地址。(注意主函数中用****作为结束输入的标志,函数fun中给出的语句仅供参考。

注意:部分源程序在文件PROG1.C中。 

请勿改动主函数main和其它函数中的任何内容,仅在函数fun的花括号中填入你编写的若干语句。 

给定源程序: 

#include <stdio.h> 

#include <string.h> 

fun(char(*a)[81],int num,char **max) 

/ * 以下代码仅供参考 */ 

int i,k=0,len, maxlen; / * ka数组中最长串所在元素的下标初始为0maxlen为其串长 */ 

maxlen=strlen(a[k]); 

for(i=1;i<num;i++) 

/ * 以下完成查找最长串 */ 

*max=a[k]; 

main() 

char ss[10][81],*ps; 

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(); 

解题思路: 

本题是考察考生怎样从已输入的字符串中找出长度最大的字符串。求字符串的长度可以使用strlen函数。 

参考答案: 

fun(char(*a)[81],int num,char **max) 

/ * 以下代码仅供参考 */ 

int i,k=0,maxlen; / * ka数组中最长串所在元素的下标,初始为0maxlen为其串长 */ 

maxlen=strlen(a[k]); 

for(i=1;i<num;i++) 

/ * 以下完成查找最长串 */ 

if(strlen(a[i]) > maxlen) { 

maxlen = strlen(a[i]) ; 

k = i ; 

*max=a[k]; 

※※※※※※※※※※※※※※※※※※※※※※※※※ 


查看更多