蓝桥杯 java 凑算式 16年省赛Java组真题

题目

思路:

求有多少种解法 比如:6+8/3+952/714就是一种解法,5+3/1+972/486 是另一种解法

8/3+952/714是可以除尽的 但是后面一个不行 所以我们也要通分

代码:

复制代码
public class 凑算式 {
    static int[] a = {1, 2, 3, 4, 5, 6, 7, 8, 9};
    static int cnt = 0;//记录解法

    // 判断 式子是否成立
    private static boolean check() {
        //A=a0 B=a1 c = a2    DEF=X GHI=Y
        // 分母=a2*y 分子=a1*y+a2*x
        //通分:((a1*y+a2*x/a1*y==0)&&a0+a1/b2)==10
        int x = a[3] * 100 + a[4] * 10 + a[5];
        int y = a[6] * 100 + a[7] * 10 + a[8];
        if ((a[1] * y + a[2] * x) %( a[2] * y) == 0 && a[0] + (a[1] * y + a[2] * x) / (a[2] *y) == 10) {
            return true;
        }
        return false;
    }

    static void f(int step) {
        // step=9说明已经排完了
        if (step == 9) {
            if (check()) {
                cnt++;
            }
        }
        // 填数 找不同的数的排列的模板写法
        for (int i = step; i < 9; i++) {
            int t = a[i];
            a[i] = a[step];
            a[step] = t;
            // 填完一个数之后递归填下一个
            f(step+1);
            // 回溯
            t = a[i];
            a[i] = a[step];
            a[step] = t;
        }
    }

    public static void main(String[] args) {
        f(0);
        System.out.println(cnt);
    }
}
相关推荐
Fuly102410 小时前
技术经理面试相关--技术篇
面试·职场和发展
c++之路10 小时前
C++20概述
java·开发语言·c++20
玛丽莲茼蒿10 小时前
Leetcode hot100 每日温度【中等】
算法·leetcode·职场和发展
Championship.23.2410 小时前
Linux Top 命令族深度解析与实战指南
java·linux·服务器·top·linux调试
橘子海全栈攻城狮10 小时前
【最新源码】养老院系统管理A013
java·spring boot·后端·web安全·微信小程序
逻辑驱动的ken10 小时前
Java高频面试考点18
java·开发语言·数据库·算法·面试·职场和发展·哈希算法
冷雨夜中漫步11 小时前
Claude Code源码分析——Claude Code Agent Loop 详细设计文档
java·开发语言·人工智能·ai
直奔標竿11 小时前
Java开发者AI转型第二十六课!Spring AI 个人知识库实战(五)——联网搜索增强实战
java·开发语言·人工智能·spring boot·后端·spring
xin_nai11 小时前
LeetCode热题100(Java)(5)普通数组
算法·leetcode·职场和发展
fzil00111 小时前
自动投递简历 + 面试进度跟踪
人工智能·面试·职场和发展