1 ~ 9 每个数只能用一次 组成各类运算公式
来源:互联网 发布:windows卸载程序在哪里 编辑:程序博客网 时间:2024/05/24 02:44
#include <stdio.h>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
- 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之位运算取得数组中只出现一次的一个数
- 【模板】并查集
- URL和URI的区别
- Gradle实现 Apk包名设置 项目内versions name 设置
- ADSL 拨号重连
- 【mysql】mycat简介
- 1 ~ 9 每个数只能用一次 组成各类运算公式
- cudnn报错Loaded runtime CuDNN library: 5005 (compatibility version 5000) but source was compiled with
- 【资源整合】
- log4j2 实际使用详解
- TCP/IP 学习三-IP网际协议
- python安装第三方库超时报错“Read time out”的解决办法
- 基尼不纯度(Gini impurity)
- 整理菜单住方法(子类归属父类)
- Redux中间件源码理解