是一只有梦想的咸鱼 2020-02-18 21:55 采纳率: 75%
浏览 657
已采纳

奶牛乘法1【数组基础】

做厌了乘法计算题的佳佳,自创了一种新的乘法运算法则。在这套法则里,A×B等于一个取自A,一个取自B所有数字对的乘积的和。
例如,123*45等于1*4+1*5+2*4+2*5+3*4+3*5=54
本题的任务是,对于给定的数A和B,用新的乘法法则计算A*B的值。

#include <stdio.h>
#include <string.h>
#include <math.h>
int main()
{
    int n,m,sum=0,i,j;
    int a[10],b[10];
    scanf("%d %d",&n,&m);
    for(i=0;i<strlen(n);i++)
    {
        a[i]=n%10;
        n=n/10;
    }
    for(i=0;i<strlen(m);i++)
    {
        b[i]=m%10;
        m=m/10;
    }
    for(i=0;i<strlen(n);i++)
    {
        for(j=0;j<strlen(m);i++)
        {
            sum=sum+a[i]*b[j];
        }
    }
    printf("%d",sum);
    return 0;

请大大指正一下,指出问题就好了

  • 写回答

1条回答 默认 最新

  • threenewbee 2020-02-18 22:05
    关注

    for(i=0;i<strlen(m);i++)
    m是整数,不应该调用strlen

    按照你的思路给你修改了下,注意这个程序只支持VC++,gcc需要自己实现 itoa 这个函数

    #include <stdio.h>
    #include <stdlib.h>
    #include <string.h>
    #include <math.h>
    int main()
    {
        int n1,m1,sum=0,i,j;
        int a[10],b[10];
        scanf("%d %d",&n1,&m1);
        char n[100];
        char m[100];
        itoa(n1, n, 10);
        itoa(m1, m, 10);
        for(i=0;i<strlen(n);i++)
        {
            a[i]=n1%10;
            n1=n1/10;
        }
        for(i=0;i<strlen(m);i++)
        {
            b[i]=m1%10;
            m1=m1/10;
        }
        for(i=0;i<strlen(n);i++)
        {
            for(j=0;j<strlen(m);j++) //注意这里是j++不是i++
            {
                sum=sum+a[i]*b[j];
            }
        }
        printf("%d",sum);
        return 0;
    }
    
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

悬赏问题

  • ¥100 求三轴之间相互配合画圆以及直线的算法
  • ¥100 c语言,请帮蒟蒻写一个题的范例作参考
  • ¥15 名为“Product”的列已属于此 DataTable
  • ¥15 安卓adb backup备份应用数据失败
  • ¥15 eclipse运行项目时遇到的问题
  • ¥15 关于#c##的问题:最近需要用CAT工具Trados进行一些开发
  • ¥15 南大pa1 小游戏没有界面,并且报了如下错误,尝试过换显卡驱动,但是好像不行
  • ¥15 自己瞎改改,结果现在又运行不了了
  • ¥15 链式存储应该如何解决
  • ¥15 没有证书,nginx怎么反向代理到只能接受https的公网网站