乘法竖式(abc*de)

本文介绍了一个通过验证特定数字组合是否能构成有效数学运算的算法。该算法遍历所有可能的三位数与两位数相乘的情况,并检查这些数字是否仅由给定的一组数字组成。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

这是横式:

111*11=1221

这是竖式:

  111

*  11

------

1221



#include <stdio.h>

#include <stdlib.h>
#include <math.h>
#include <time.h>
#include <string.h>

#define MAXN 20
#define MAXM 60

int main()
{
    char s[MAXN],buf[MAXM];
    int a,b,x,y,z,count=0,i,ok;
    scanf("%s",s);
    for(a=100; a<=999; a++)
        for(b=10; b<=99; b++)
        {
            //对被乘数进行拆解然后再跟乘数求积
            x=a*(b%10);
            y=a*(b/10);
            z=a*b;
            sprintf(buf,"%d%d%d%d%d",a,b,x,y,z);
            ok=1;
            //判断乘数、被乘数、其中间过渡量以及结果是否只包含给出的数字
            for(i=0; i<strlen(buf); i++)
                if(strchr(s,buf[i])==NULL)
                {
                    ok=0;
                    break;
                }
            if(ok==1)
            {
                printf("<%d>\n",++count);
                printf("%5d\nX%4d\n-----\n%5d\n%4d\n-----\n%5d\n",a,b,x,y,z);
            }
        }

    return 0;
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值