除法(Division, UVa 725)

先对分子的五位数进行排列,如若两两不相等,则乘上给的积得到分母

将分母拆分成五位数,对以上的十位数再次判断是否两两不相等

如若两两不相等,输出

利用set容器判断是不是两两不相等,

#include <iostream>
#include <cstring>
#include <set>
using namespace std;
bool different(int a, int b, int c, int d, int e, int f, int g, int h, int i, int j)
{
	set<int> s;
	s.insert(a); s.insert(b); s.insert(c); s.insert(d); s.insert(e);s.insert(f); s.insert(g);
	s.insert(h); s.insert(i); s.insert(j);
	return s.size() == 10;
}
bool different(int a, int b, int c, int d, int e)
{
	set<int> s;
	s.insert(a); s.insert(b); s.insert(c); s.insert(d); s.insert(e);
	return s.size() == 5;
}
void print(int N)
{
	int ok = 0;
	for(int f = 0; f <= 9; f++)
		for(int g = 0; g <= 9; g++)
			for(int h = 0; h <= 9; h++)
				for(int i = 0; i <= 9; i++)
					for(int j = 0; j <= 9; j++)
						if(different(f,g,h,i,j) )
						{
							
								int numerator = j + i*10 + h*100 + g*1000 + f*10000;
								int denominator = N*numerator;
								if(denominator >= 12345 && denominator <= 98765)
								{
									int e = denominator % 10; denominator = denominator / 10;
									int d = denominator % 10; denominator = denominator / 10;
									int c = denominator % 10; denominator = denominator / 10;
									int b = denominator % 10; denominator = denominator / 10;
									int a = denominator % 10; denominator = denominator / 10;
									if(different(a,b,c,d,e,f,g,h,i,j) )
									{
										ok = 1;
										cout<<a<<b<<c<<d<<e<<" / "<<f<<g<<h<<i<<j<<" = "<<N<<endl;
									}
								}
						}
	if(ok == 0)	
		cout<<"There are no solutions for " << N << "."<<endl;
}
int main()
{
	int N, kn = 0;
	while(cin >> N && N) 
	{
		if(kn) cout<<endl; kn++;
		print(N);
	}
	return 0;
}


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值