试题如图所示:
C语言解答如下(VS2013通过):
#define _CRT_SECURE_NO_WARNINGS
#include
int main()
{
int max = 0;
printf("请输入:\n");
int n = 0;
int m = 0;
char input1[100] = { 0 };
gets(input1);
sscanf(input1, "%d %d", &n, &m);
/*************动态分配二维数组**************/
int **C = (int **)malloc(sizeof(int *)*n*m);//分配指针数组
C[0] = (int *)malloc(sizeof(int)*n*m);//一次性分配所有空间
for (int ix = 1; ix < n; ix++)
{
C[ix] = C[ix - 1] + m*4;
}
/*************动态分配二维数组**************/
long **Multiply = (long **)malloc(sizeof(long *)*n*m*2);//分配指针数组
Multiply[0] = (long *)malloc(sizeof(long)*n*m);//一次性分配所有空间
for (int ix = 1; ix < n; ix++)
{
Multiply[ix] = Multiply[ix - 1] + m * 8;
}
int row = 0;
int col = 0;
while (n != 0)
{
char s[100] = { 0 };
gets(s);
col = 0;
char *p = strtok(s, " ");
while (p)
{
C[row][col++] = atoi(p);
p = strtok(NULL, " ");
}
n--;
row++;
}
printf("-------------------------\n");
for (int i = 0; i < row;++i)
{
for (int j = 0; j < col;++j)
{
printf("%d ", C[i][j]);
}
printf("\n");
}
for (int i = 0; i < row;++i)
{
for (int j = 0; j < col;++j)
{
int tmp = C[i][j];
if (0==tmp)
{
Multiply[i][j] = 0;
}
else
{
int m = 1;
for (int ii = i, jj = 0; jj < col; ++jj)
{
m *= C[ii][jj];
}
for (int ii = 0, jj = j; ii < row; ++ii)
{
m *= C[ii][jj];
}
Multiply[i][j] = m;
Multiply[i][j] /= tmp;
Multiply[i][j] /= tmp;
}
}
}
printf("-------------------------\n");
for (int i = 0; i < row; ++i)
{
for (int j = 0; j < col; ++j)
{
printf("%d ", Multiply[i][j]);
}
printf("\n");
}
printf("------------最大值:-------------\n");
max = Multiply[0][0];
for (int i = 0; i < row; ++i)
{
for (int j = 0; j < col; ++j)
{
max = (max > Multiply[i][j]) ? max : Multiply[i][j];
}
}
printf("%ld\n", max);
return 0;
}
特别注意动态分配二维数组的方法!
结果如下:
但是在编译过程中发生了下面的错误(如果没有发生异常,则不会有这个问题,一旦没有语法错误的情况下运行异常,下次再编译就会发生下面的错误):
error link 1168:
和error link 1104:
网上的解决办法基本都是找到相应的EXE进程,并关掉即可。但是我在电脑的任务管理器中始终找不到这个相应的EXE程序,无奈之下只能借助360文件粉碎机将这个EXE程序彻底删除,然后才可以重新编译了。