递归简单用法2(算式填符号)

题目

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.如果递归中出现数据的改变需要还原

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值