啊哈,算法 !--火柴棍公式 ( C语言版 )

题目 : 假如现手中有m(m<=24)个火柴棍,希望拼出A+B=C等式。等式中的A、B、C均为火柴棍拼出来的整数(若该数非0,则最高位不能为0)。

注意:

  • 1、加号与等号各自需要2根火柴棍;
  • 2、如果A不等于B,则A+B=C与B+A=C视为不同的等式(三者均大于0);
  • 3、所有根火柴棍必须全都用上。

思路:24根除去 '+' 和 '=' 4根还有20根,而数字1所需火柴棍最少,需2根。则三者中任一数不能超过1111。只需枚举A和B, C可以通过A和B计算。A中火柴棍数加上B中火柴棍数等于C中火柴棍数,若恰好等于m-4的话,则成功找出一组解。

代码如下 :

#define _CRT_SECURE_NO_WARNINGS
#include <stdio.h>
#include <stdlib.h>
int Fun(int n)
{
	//用数组列出0-9没一个数所需要的火柴棍数
	int arr[10] = { 6, 2, 5, 5, 4, 5, 6, 3, 7, 6};
	int ret = 0;
	//判断n是不是两位数或更高位数
	while (n / 10 != 0){
		//将个位数所需要的火柴棍数相加
		ret += arr[n % 10];
		//更新n的个位数
		n /= 10;
	}
	//最后加上此时n需要的火柴棍数(n是一位数)
	ret += arr[n];
	return ret;
}
int main()
{
	int a, b, c, m, num = 0;
	printf("请输入火柴棍的个数\n");
	scanf("%d", &m);
	//枚举a和b
	for (a = 0; a <= 1111; a++){
		for (b = 0; b <= 1111; b++){
			c = a + b;
			//判读是否符合条件
			if (Fun(a) + Fun(b) + Fun(c) == m - 4){
				printf("%d + %d = %d\n", a, b, c);
				//计算所有可能的个数
				num++;
			}
		}
	}
	printf("一共可以拼出%d个不同等式\n", num);
	system("pause");
	return 0;
}

调试结果 :

若有出错或不懂的地方,​ 欢迎留言, 共同进步 !

猜你喜欢

转载自blog.csdn.net/ds19980228/article/details/82498802