20200310之凑算式 (填空 全排列)

在这里插入图片描述
这个算式中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;
} 
发布了37 篇原创文章 · 获赞 0 · 访问量 377

猜你喜欢

转载自blog.csdn.net/weixin_45351699/article/details/104780450
今日推荐