填空题 给定程序中,函数fun的功能是:将a所指3×5矩阵中第k列的元素左移到第0列,第k列以后的每列元素依次左移,原来左边的各列依次绕到右边。
例如,有下列矩阵:
1 2 3 4 5
1 2 3 4 5
1 2 3 4 5
若k为2,程序执行结果为
3 4 5 1 2
3 4 5 1 2
3 4 5 1 2
请在程序的下划线处填入正确的内容并把下划线删除,使程序得出正确的结果。
注意:源程序存放在考生文件夹下的BLANK1.C中。
不得增行或删行,也不得更改程序的结构!
给定源程序如下。
#include<stdio.h>
#define M 3
#define N 5
void fun(int(*a)[N],int k)
{ int i,j,p,temp;
/*********found********/
for(p=1;p<= 1;p++)
for(i=0;i<M;i++)
{ temp=a[i][0];
/***********found*********/
for(j=0;j< 2;j++)
a[i][j]=a[i][j+1];
/********found***********/
a[i][N-1]= 3;
}
}
main()
{ int x[M][N]={ {1,2,3,4,5},{1,2,3,4,5},{1,2,3,4,5}},i,j;
printf("The array before moving:/n/n");
for(i=0;i<M;i++)
( for(j=0;j<N;j++)printf("%3d",x[i][j]);
printf("/n");
}
fun(x,2);
printf("The array after moving:/n/n");
for(i=0;i<M;i++)
{ for(j=0;j<N;j++)printf("%3d",x[i][j]);
printf("/n");
}
}
【正确答案】
【答案解析】k N-1 temp [解析] 填空1:外循环p的值为数组移动的次数,试题要求第k列左移,则需要移动的次数为k,所以应填k。
填空2:矩阵共N列,所以应填N-1。
填空3:临时变量temp中存放的值为数组最左边元素的值,需要把temp放到数组的末尾,即放到a[i][N-1]中,所以应填temp。