蓝桥杯第八届真题 :9数算式

点击查看:蓝桥杯历年真题 题解目录
9数算式

在这里插入图片描述

评测标准答案:1625
1.首先,对1~9进行全排列,然后对每种排列进行"乘号"位置的排列
2.在对乘号位置确定后,要保证"乘号两边的乘数"正确
3.用乘数的结果,即等号右边的值进行判断 。
   check 1. 长度为9 ;    check 2. 长度为9时不包含数字0,无重复元素。
4. 最终结果除以2,题目已说明两乘数交换位置 视为一种情况。
import java.util.Set;
import java.util.HashSet;
public class Main002_9数算式{
    static int[]a = {1,2,3,4,5,6,7,8,9};
    static int count;
    public static void main(String[] args) {
  	per(0);
  	int ans = count/2;
  	System.out.println(ans);
    }
    private static void per(int k) {
  	if(k==9) {
   	    for(int i=1;i<=8;i++) {
    	    	int x1 = algor(0,i);
    	    	int x2 = algor(i,9);
    	    	if(check(x1*x2)) 
     		    count++;
            }
        }
        // 全排列(递归版本)
        for(int i=k;i<9;i++) {
  	    int t = a[i];
   	    a[i] = a[k];
   	    a[k] = t;
   	    per(k+1);
   	    t = a[i];
   	    a[i] = a[k];
   	    a[k] = t;
        }
    }
    //  判断等号右边的数是否符合条件
    private static boolean check(int x) {
  	String s=x+"";
  	if(s.length()!=9 || s.indexOf('0')>-1) return false;
  	Set<Character> set = new HashSet<>();
  	for(int i=0;i<s.length();i++) 
   	    set.add(s.charAt(i));
  	return set.size()==9;
    }
    // 将零散的整数 组成乘数
    private static int algor(int i, int j) {
  	int x = 0;
  	int p = 1;
  	for(int k=j-1;k>=i;k--) {
   	    x+=a[k]*p;
   	    p*=10;
  	}
  	return x;
    }
}
  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值