这个算式中A-I代表1-9的数字,不同的字母代表不同的数字。
比如:
6+8/3+952/714就是一种解法,
5+3/1+972/486是另一种解法。
这个算式一共有多少种解法?
注意:你提交应该是个整数,不要填写任何多余的内容或说明性文字。
这题万万万没想到是double!!根据之前学过的“算式900”,这样算数的题我们都可以用全排列来实现,比暴力等方法易懂且简洁。
但!!!
本来还质疑第一个算式怎么成立的呢?没多想直接开int数组做了,没想到第一个式子就是引导我们要保留小数,用double类型。还是什么事情都要多想一下,研究明白每个条件啊!
#include <bits/stdc++.h>
using namespace std;
//答案:29
int sum=0;
double a[9]; //就是这个double!!!!!!!!!!!!!!!!!!!!!!!!
int main(){
for(int i=0;i<=8;i++)
a[i]=i+1;
do{
if((a[0]+a[1]/a[2]+(a[3]*100+a[4]*10+a[5])/(a[6]*100+a[7]*10+a[8]))==10)
sum++;
}while(next_permutation(a,a+9));
cout<<sum<<endl;
return 0;
}