题目
1,2,3,4,5,6,7,8,9九个数在他们中间填加号和减号或者合并两个数(例如8,9合并为89)使其结果为110(九个数都要用上)二、代码
代码如下(示例):
package com.hzc.bluecap;
import java.util.Scanner;
public class Recurrence02 {
public static void main(String[] args) {
// TODO Auto-generated method stub
int[] a= {1,2,3,4,5,6,7,8,9};
f(a,8,"",110);
}
private static void f(int[] a,int k, String str,int goal) {
// TODO Auto-generated method stub
if(k==0) {
if(a[0]==goal) {
System.out.println(a[0]+str);
}
return;
}
f(a,k-1,"+"+a[k]+str,goal-a[k]);
f(a,k-1,"-"+a[k]+str,goal+a[k]);
int old=a[k-1];
a[k-1]=Integer.parseInt(""+a[k-1]+a[k]);
f(a,k-1,str,goal);
a[k-1]=old;//将改变的数据还原
}
}
思维过程
1,2,3,4,5,6,7,8,9填入符号结果为110假如前面8位数计算得结果为101则要加最后一位数如果为119则要减掉最后一位数以此类推第8个数字前面的符号然后用递归的思维很容易想到
演算步骤:
1.所有数字填如符号=110
2.(前8个数字填入符号的结果)+或-9=101或119(既前八位数字填入符号=109)
或者是直接合并如果直接合并结果则还是为110
3.(前7个数字填入符号的结果)+或-8=93或109或111或127
或者是直接合并如果直接合并结果则还是为110
。。。。。(后面类似,其实很多递归的图和二叉树的图很像)
4.当k指到0时意味着数都走完了进行判断当a[0]=goal时输出
str再跳出如果不是则直接跳出(其实和加减法两边对换差不多a[0]=110-(后面已经整理好的8位数)=1或合并后的数值)
总结
1.有些递归和二叉树很像
2.如果递归中出现数据的改变需要还原