解题思路:
注意事项:
参考代码:
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分
1 人评分
C语言网提供由在职研发工程师或ACM蓝桥杯竞赛优秀选手录制的视频教程,并配有习题和答疑,点击了解:
一点编程也不会写的:零基础C语言学练课程
解决困扰你多年的C语言疑难杂症特性的C语言进阶课程
从零到写出一个爬虫的Python编程课程
只会语法写不出代码?手把手带你写100个编程真题的编程百练课程
信息学奥赛或C++选手的 必学C++课程
蓝桥杯ACM、信息学奥赛的必学课程:算法竞赛课入门课程
手把手讲解近五年真题的蓝桥杯辅导课程
发表评论 取消回复