使用VC++2010打开考生文件夹下blank1中的解决方案。此解决方案的项目中包含一个源程序文件blank1.c。在此程序中,函数fun的功能是:将a所指3×5矩阵中第k列的元素左移到第0列,第k列以后的每列元素行依次左移,原来左边的各列依次绕到右边。

admin2019-03-06  35

问题 使用VC++2010打开考生文件夹下blank1中的解决方案。此解决方案的项目中包含一个源程序文件blank1.c。在此程序中,函数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 M3
#define N5
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[0];
/*********found*********/
for(j=0;j<【2】;j++)
a[j]=a[j+1];
/*********found*********/
a[N﹣1]=【3】
}
}
main()
{int x[M][N]=f{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[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[j]),
printf("\n");
}
}

选项

答案(1)k (2)N﹣1 (3)temp

解析 填空1:外循环p的值为数组移动的次数,试题要求第k列左移,则需要移动的次数为k,所以应填k。
填空2:矩阵共N列,所以应填N﹣1。
填空3:临时变量temp中存放的值为数组最左边元素的值,需要把temp放到数组的末尾,即放到a[N﹣1]中,所以应填temp。
转载请注明原文地址:https://jikaoti.com/ti/8kf0FFFM
0

最新回复(0)