1 ~ 9 每个数只能用一次 组成各类运算公式
来源:互联网 发布:java swing listview 编辑:程序博客网 时间:2024/06/05 11:07
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;
}
- 1 ~ 9 每个数只能用一次 组成各类运算公式
- 1 ~ 9 每个数只能用一次 组成各类运算公式
- 趣味数学--用1到9这九个数组成一个四位数乘以一位数等于四位数的等式,每个数只能用一次
- 用1,2,3……,9组成3个三位数,比例为1:2:3,且每个数只能用一次。
- 三位数相加,1 ~ 9 只能用一次
- 将1,2,3,4,5,6,7,8,9九个数字分成以下三种形式之一,每个数字只能用一次,使得该分数刚好为一个整数
- 位运算求数组中只出现一次的数
- Combination Sum II 无序数组中找组合(每个元素只能用一次)使得和为target@LeetCode@LeetCode
- 用1,2,3…9组成3个三位数abc, def, ghi, 每个数字恰好使用一次,且abc:def:ghi=1:2:3,输出所有解。 用1,2,3…9组成3个三位数abc, def, ghi, 每个数
- Perl中的文件句柄“只能用一次”
- 有一个排好序的数列,数列中只有一个数只出现1次,其余每个数均出现了两次,设计出一个算法,找出那个只出现了一次的数
- python的文件句柄一次只能用一次
- 随机打印1-100的数,每个只能打印一次
- 只出现一次的数
- 只出现一次的数
- 只出现一次的数
- 找数组中只出现一次的两个数 位运算
- leetcode之位运算取得数组中只出现一次的一个数
- 论文学习:二值神经网络BNN-用+1或-1限制的权值和激活函数来训练神经网络
- 二进制数与十进制数相互转换 string陷阱(赋值错误) 汉字分为两个字符 string123 string字符串逆转
- 神经网络的直观解释
- dubbo配置详解
- POJ 1136 Pendulum 笔记
- 1 ~ 9 每个数只能用一次 组成各类运算公式
- 比赛总结(中原工学院校赛)
- Java 集合(一)
- java单元测试工具:JUnit4(二)——测试失败、运行流程及常用注解
- 哈希表(散列表)原理详解
- 开博了!
- 类图(Class Diagram)
- GitHub拉取非master分支代码
- rnn学习资料整理