蓝桥杯竞赛题——第七届第3题【凑算式】
2018-03-21 21:25
162 查看
凑算式
B DEF
A + --- + ------- = 10
C GHI
(如果显示有问题,可以参见【图1.jpg】)
这个算式中A~I代表1~9的数字,不同的字母代表不同的数字。
比如:
6+8/3+952/714 就是一种解法,
5+3/1+972/486 是另一种解法。
这个算式一共有多少种解法?
注意:你提交应该是个整数,不要填写任何多余的内容或说明性文字。
答案:29
方法一:暴力package 第七届;
public class Three {
public static void main(String[] args) {
double A,B,C,D,E,F,G,H,I,n=0;
for(A=1;A<10;A++)
{
for(B=1;B<10;B++)
{ if(A!=B)
for(C=1;C<10;C++)
{ if(A!=C&&B!=C)
for(D=1;D<10;D++)
{ if(A!=D&&B!=D&&C!=D)
for(E=1;E<10;E++)
{ if(A!=E&&B!=E&&C!=E&&D!=E)
for(F=1;F<10;F++)
4000
{ if(A!=F&&B!=F&&C!=F&&D!=F&&E!=F)
for(G=1;G<10;G++)
{ if(A!=G&&B!=G&&C!=G&&D!=G&&E!=G&&F!=G)
for(H=1;H<10;H++)
{ if(A!=H&&B!=H&&C!=H&&D!=H&&E!=H&&F!=H&&G!=H)
for(I=1;I<10;I++)
{ if(A!=I&&B!=I&&C!=I&&D!=I&&E!=I&&F!=I&&G!=I&&H!=I)
{
if(A+(B/C)+((D*100+E*10+F)/(G*100+H*10+I))==10)
{
n++;
}
}
}
}
}
}
}
}
}
}
}
System.out.println(n);
}
}
方法二:全排列算法package 第七届;
import java.util.*;
public class Three {
static int count=0;
public static void swap(double[] s,double a,double b) {
double temp;
temp=s[(int) a];
s[(int) a]=s[(int) b];
s[(int) b]=temp;
}
public static void sort(double[] s,double cursor,double end){
if (cursor==end) {
if (s[0]+s[1]/s[2]+(s[3]*100+s[4]*10+s[5])/(s[6]*100+s[7]*10+s[8])==10) {
count++;
}
// for (int i = 0; i < s.length; i++) {
// System.out.print(s[i]); //打印所有结果
//
// }
// System.out.println();
} else {
for (double i = cursor; i < end; i++) {
swap(s,cursor,i);
sort(s, cursor+1 , end);
swap(s,cursor,i);
}
}
}
public static void main(String[] args) {
double[] s=new double[]{1,2,3,4,5,6,7,8,9};
double cursor=0;
double end=s.length;
sort(s, cursor, end);
System.out.println(count);
}
}
B DEF
A + --- + ------- = 10
C GHI
(如果显示有问题,可以参见【图1.jpg】)
这个算式中A~I代表1~9的数字,不同的字母代表不同的数字。
比如:
6+8/3+952/714 就是一种解法,
5+3/1+972/486 是另一种解法。
这个算式一共有多少种解法?
注意:你提交应该是个整数,不要填写任何多余的内容或说明性文字。
答案:29
方法一:暴力package 第七届;
public class Three {
public static void main(String[] args) {
double A,B,C,D,E,F,G,H,I,n=0;
for(A=1;A<10;A++)
{
for(B=1;B<10;B++)
{ if(A!=B)
for(C=1;C<10;C++)
{ if(A!=C&&B!=C)
for(D=1;D<10;D++)
{ if(A!=D&&B!=D&&C!=D)
for(E=1;E<10;E++)
{ if(A!=E&&B!=E&&C!=E&&D!=E)
for(F=1;F<10;F++)
4000
{ if(A!=F&&B!=F&&C!=F&&D!=F&&E!=F)
for(G=1;G<10;G++)
{ if(A!=G&&B!=G&&C!=G&&D!=G&&E!=G&&F!=G)
for(H=1;H<10;H++)
{ if(A!=H&&B!=H&&C!=H&&D!=H&&E!=H&&F!=H&&G!=H)
for(I=1;I<10;I++)
{ if(A!=I&&B!=I&&C!=I&&D!=I&&E!=I&&F!=I&&G!=I&&H!=I)
{
if(A+(B/C)+((D*100+E*10+F)/(G*100+H*10+I))==10)
{
n++;
}
}
}
}
}
}
}
}
}
}
}
System.out.println(n);
}
}
方法二:全排列算法package 第七届;
import java.util.*;
public class Three {
static int count=0;
public static void swap(double[] s,double a,double b) {
double temp;
temp=s[(int) a];
s[(int) a]=s[(int) b];
s[(int) b]=temp;
}
public static void sort(double[] s,double cursor,double end){
if (cursor==end) {
if (s[0]+s[1]/s[2]+(s[3]*100+s[4]*10+s[5])/(s[6]*100+s[7]*10+s[8])==10) {
count++;
}
// for (int i = 0; i < s.length; i++) {
// System.out.print(s[i]); //打印所有结果
//
// }
// System.out.println();
} else {
for (double i = cursor; i < end; i++) {
swap(s,cursor,i);
sort(s, cursor+1 , end);
swap(s,cursor,i);
}
}
}
public static void main(String[] args) {
double[] s=new double[]{1,2,3,4,5,6,7,8,9};
double cursor=0;
double end=s.length;
sort(s, cursor, end);
System.out.println(count);
}
}
相关文章推荐
- \第七届蓝桥杯大赛个人赛省赛(软件类)3 凑算式 【全排列解法】
- 第七届蓝桥杯JAVAb组第三题凑算式
- 第七届蓝桥杯 省赛 JavaB组 凑算式
- 第七届蓝桥杯C++B组 凑算式
- 2016第七届蓝桥杯C/C++ B组省赛第三题:凑算式
- 凑算式-第七届蓝桥杯c/c++B组
- 第七届蓝桥杯javaB组省赛第3题
- 第七届蓝桥杯大赛个人赛省赛(软件类)java语言B组第三题:凑算式
- 第七届蓝桥杯【省赛试题3】凑算式
- 第七届蓝桥杯B组 第三题 凑算式
- 蓝桥杯-第七届省赛javaB组-凑算式
- 第七届蓝桥杯凑算式
- 第七届蓝桥杯JAVA B组真题解析-凑算式(第三题)
- 第七届蓝桥杯【省赛试题3】凑算式
- 第七届java蓝桥杯之凑算式
- 第七届蓝桥杯B组 第三题 凑算式
- 第七届蓝桥杯b组第三题-凑算式
- 2016第七届蓝桥杯 06 凑算式(java)
- 第七届蓝桥杯JAVA语言B组_凑算式
- 第七届蓝桥杯软件类省赛真题-C-B-3_凑算式