今天是做比赛总结的第二天,今天总结的是用暴力解法解决题目。这种方法常常用在解决例如凑算式等问题的求解上,思路比较简单,所以考点一般设置在对于细节的处理上面,换句话讲,如果细节处理不当,很容易造成丢分。具体来说,有这么一道题,就是典型的暴力解法(第七届蓝桥杯第三题)的应用:
凑算式
B DEF
A + --- + ------- = 10
C GHI
这个算式中A~I代表1~9的数字,不同的字母代表不同的数字。
比如:
6+8/3+952/714 就是一种解法,
5+3/1+972/486 是另一种解法。
这个算式一共有多少种解法?
乍一看这道题,第一眼的感觉就是使用暴力求解。设置9层循环,暴力枚举,如果最终可以使结果为10,并且没有重复的数字,就将其看作是一种有效的解法,不过也有要特别注意的地方。因为在大多数编程语言里面,存在着类型转换的问题,如果两个int型数据运算,最终的结果也是int型,不会转换成其余的类型,而我们进行的是数学意义上的运算,所以必须要进行类型转换,具体代码如下
package hoLidayPraRewie;
/*
* @author理工吴彦祖
* @Info在校大学生,欢迎交流 妹子优先
*/
public class CountOfEquation {
//总的结果
public static int count=0;
//特别注意这个a1和a2的求法
public static double a1