解题思路:

注意事项:

参考代码:

import java.util.Scanner;

public class Main {

    static int ans;

    static int N;

public static void main(String[] args) {

Scanner sc = new Scanner(System.in);

    N = sc.nextInt();

int [] arr = {1,2,3,4,5,6,7,8,9};

dfs(0, arr);

        System.out.println(ans);

}

//全排列

public static void dfs(int i,int[] arr) {

if(i == arr.length - 1) {//找到一种排列时

check(arr);//检查放入加号和乘号能否符合要求

return;

}

for (int k = i; k < arr.length; k++) {//对于每一个i位置以后的元素都可放到这个i位置构成一种可能的排列顺序

swap(arr, i, k);

dfs(i + 1, arr);

swap(arr, i, k);//回溯

}

}

public static void check(int[] arr) {

//加号前面的字符数最多有七个

for (int i = 1; i <= 7; i++) {//最少1个最多七个

int num1 = toInt(arr, 0, i);//加号前面的数字

if (num1 >= N) {

continue;

}

//除法前面的数字

for (int j = 1; j < 9 - i; j++) {//最少1个最多7个

int num2 = toInt(arr, i, i + j);

int num3 = toInt(arr, i + j, 9);

if(num2 % num3 == 0 && num1 + num2 / num3 == N) {//需要保证 num2和num3一定是逻辑整除关系

ans++;

}

}

}

}

//转换数字 从最后一位开始遍历

public static int toInt(int[] arr,int start,int end) {

int res = 0;

int mul = 1;//乘数因子

for (int i = end - 1; i >= start; i--) {

res += arr[i] * mul;

mul *= 10;

}

return res;

}

//交换位置代码

public static void swap(int[] arr,int i,int j) {

int tmp = arr[i];

arr[i] = arr[j];

arr[j] = tmp;

}


点赞(0)
 

0.0分

1 人评分

C语言网提供由在职研发工程师或ACM蓝桥杯竞赛优秀选手录制的视频教程,并配有习题和答疑,点击了解:

一点编程也不会写的:零基础C语言学练课程

解决困扰你多年的C语言疑难杂症特性的C语言进阶课程

从零到写出一个爬虫的Python编程课程

只会语法写不出代码?手把手带你写100个编程真题的编程百练课程

信息学奥赛或C++选手的 必学C++课程

蓝桥杯ACM、信息学奥赛的必学课程:算法竞赛课入门课程

手把手讲解近五年真题的蓝桥杯辅导课程

评论列表 共有 0 条评论

暂无评论