蓝桥杯官网填空题(算式问题)

题目描述

本题为填空题,只需要算出结果后,在代码中使用输出语句将所填结果输出即可。

看这个算式:

☆☆☆ + ☆☆☆ = ☆☆☆

如果每个五角星代表 1 ~ 9 的不同的数字。

这个算式有多少种可能的正确填写方法?

复制代码
173 + 286 = 459 
295 + 173 = 468 
173 + 295 = 468 
183 + 492 = 675

以上都是正确的填写法!

注意:111+222=333 是错误的填写法! 因为每个数字必须是不同的! 也就是说: 1 ~ 9中的所有数字,每个必须出现且仅出现一次!

注意:不包括数字 "0"!

注意: 满足加法交换率的式子算两种不同的答案。 所以答案肯定是个偶数!

运行限制

java 复制代码
import java.util.Scanner;

public class Main {
  static int[] a=new int[9];
  static int[] biaoji=new int[10];
  static int ans=0;
    public static void main(String[] args) {
        Scanner scan = new Scanner(System.in);
        dfs(0);
        System.out.println(ans);
        scan.close();
    }
    public static void dfs(int n){
      if(n==9){
        int a1=a[0]*100+a[1]*10+a[2];
        int a2=a[3]*100+a[4]*10+a[5];
        int a3=a[6]*100+a[7]*10+a[8];
        if(a1+a2==a3){
          ans++;
          return;
        }
        else{
          return;
        }
      }
      for(int i=1;i<=9;i++){
        if(biaoji[i]==0){
          biaoji[i]=1;
          a[n]=i;
          dfs(n+1);
          biaoji[i]=0;
        }
      }
    }
}
    • 最大运行时间:1s
    • 最大运行内存: 128M
相关推荐
jianfeng_zhu17 分钟前
不带头节点的链式存储实现链栈
数据结构·算法
lightqjx20 分钟前
【算法】双指针
c++·算法·leetcode·双指针
历程里程碑22 分钟前
C++ 7vector:动态数组的终极指南
java·c语言·开发语言·数据结构·c++·算法
mit6.82425 分钟前
get+二分|数位dp
算法
sin_hielo29 分钟前
leetcode 2147
数据结构·算法·leetcode
萌>__<新42 分钟前
力扣打卡每日一题——缺失的第一个正数
数据结构·算法·leetcode
DuHz1 小时前
车对车对向交汇场景的毫米波路径损耗建模论文精读
论文阅读·算法·汽车·信息与通信·信号处理
lxh01131 小时前
二叉树中的最大路径和
前端·算法·js
萌>__<新1 小时前
力扣打卡每日一题————零钱兑换
算法·leetcode·职场和发展
重生之后端学习1 小时前
238. 除自身以外数组的乘积
java·数据结构·算法·leetcode·职场和发展·哈希算法