(C语言)搜狗的一道在线编程题

试题如图所示:

C语言解答如下(VS2013通过):

#define _CRT_SECURE_NO_WARNINGS
#include <stdio.h>



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程序彻底删除,然后才可以重新编译了。


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值