1 ~ 9 每个数只能用一次 组成各类运算公式

int a[9] = {0};
int fun();
int main()
{
int m, n, x, y, count = 0;
//第一类 OOO + OOO = OOO 即三位数加三位数等于三位数,且1~9只能出现一次。
printf(“OOO + OOO = OOO :\n”);
for (m = 123; m <= 864; m++)
{
for (n = 987 - m; n > m ; n–)
{
if (fun(m, 3, a) && fun(n, 3, a + 3) && fun(m + n, 3, a + 6))
{
printf(“No.%d: %d + %d = %d\n”, ++count, m, n, m + n);
}
}
}
count = 0;
//第二类 O * OOOO = OOOO
printf(“\nO * OOOO = OOOO :\n”);
for (m = 1; m <= 9; m++)
{
for (n = 1234; n <= 9876; n++)
{
if (0 == m * n / 10000)
{
if (fun(m, 1, a) && fun(n, 4, a + 1) && fun(m * n, 4, a + 5))
{
printf(“No.%d: %d * %d = %d\n”, ++count, m, n, m * n);
}
}
else
{
continue;
}
}
}
count = 0;
//第三类 OO * OOO = OOOO
printf(“\nOO * OOO = OOOO :\n”);
for (m = 12; m <= 98; m++)
{
for (n = 123; n <= 987; n++)
{
if (0 == m * n / 10000)
{
if (fun(m, 2, a) && fun(n, 3, a + 2) && fun(m * n, 4, a + 5))
{
printf(“No.%d: %d * %d = %d\n”, ++count, m, n, m * n);
}
}
else
{
continue;
}
}
}
count = 0;
//第四类 O * OOO = OO * OOO
printf(“\nO * OOO = OO * OOO :\n”);
for (m = 1; m <= 9; m++)
{
for (n = 123; n <= 987; n++)
{
for (x = 12; x <= 98; x++)
{
for (y = 123; y <= 987; y++)
{
if (m * n == x * y)
{
if (fun(m, 1, a) && fun(n, 3, a + 1) && fun(x, 2, a + 4) && fun(y, 3, a + 6))
{
printf(“No.%d: %d * %d = %d * %d\n”, ++count, m, n, x, y);
}
}
else
{
continue;
}
}
}
}
}
count = 0;
//第五类 O * OOO = O * OOOO
printf(“\nO * OOO = O * OOOO :\n”);
for (m = 1; m <= 9; m++)
{
for (n = 123; n <= 987; n++)
{
for (x = 1; x <= 9; x++)
{
for (y = 1234; y <= 9876; y++)
{
if (m * n == x * y)
{
if (fun(m, 1, a) && fun(n, 3, a + 1) && fun(x, 1, a + 4) && fun(y, 4, a + 5))
{
printf(“No.%d: %d * %d = %d * %d\n”, ++count, m, n, x, y);
}
}
else
{
continue;
}
}
}
}
}
count = 0;
//第六类 OO * OO = O * OOOO
printf(“\nOO * OO = O * OOOO :\n”);
for (m = 12; m <= 98; m++)
{
for (n = 98; n > m; n–)
{
for (x = 1; x <= 9; x++)
{
for (y = 1234; y <= 9876; y++)
{
if ((m % 10) && m * n == x * y)
{
if (fun(m, 2, a) && fun(n, 2, a + 2) && fun(x, 1, a + 4) && fun(y, 4, a + 5))
{
printf(“No.%d: %d * %d = %d * %d\n”, ++count, m, n, x, y);
}
}
else
{
continue;
}
}
}
}
}
count = 0;
//第七类 OO * OO = OO * OOO
printf(“\nOO * OO = OO * OOO :\n”);
for (m = 12; m <= 98; m++)
{
for (n = 98; n > m; n–)
{
for (x = 12; x <= 98; x++)
{
for (y = 123; y <= 987; y++)
{
if ((m % 10) && m * n == x * y)
{
if (fun(m, 2, a) && fun(n, 2, a + 2) && fun(x, 2, a + 4) && fun(y, 3, a + 6))
{
printf(“No.%d: %d * %d = %d * %d\n”, ++count, m, n, x, y);
}
}
else
{
continue;
}
}
}
}
}
return 0;
}
//最最最重要的调用函数,判断9位数不相同
int fun(int t, int k, int *z)
{
int *p1, *p2;

for (p1 = z; p1 < z + k; p1++)
{
    *p1 = t % 10;
    t /= 10;

    for (p2 = a; p2 < p1; p2++)
    {
        if (*p1 == 0 || *p1 == *p2)
        {
            return 0;
        }
    }
}

return 1;

}

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值