算法--5个砝码(回溯)

5个砝码

 

用天平称重时,我们希望用尽可能少的砝码组合称出尽可能多的重量。

如果只有5个砝码,重量分别是1,3,9,27,81。则它们可以组合称出1到121之间任意整数重量(砝码允许放在左右两个盘中)。

本题目要求编程实现:对用户给定的重量,给出砝码组合方案。

例如:

用户输入:

5

程序输出:

9-3-1

用户输入:

19

程序输出:

27-9+1

 

要求程序输出的组合总是大数在前小数在后。

可以假设用户的输入的数字符合范围1~121。


import java.io.BufferedReader;
import java.io.InputStreamReader;
import java.util.Scanner;

public class Main {   
	
	private static int[] weight = {1,3,9,27,81};//砝码的重量
	private static int[] flag = {-1,0,1};//改变砝码的位置
	
	public static void main(String[] args) throws Exception {
		BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
		int n = Integer.valueOf(br.readLine());
		fun(n,0);		
	}

	private static void fun(int n,int k) {
		if(k==weight.length){
			check(n);//格式化输出结果
			return ;
		}
		
		for(int i=0;i<3;i++){
			int temp = weight[k];
			weight[k]=weight[k]*flag[i];//改变状态
			fun(n,k+1);
			weight[k] = temp;//回溯,还原初始状态
		}
	}

	private static void check(int n) {
		int sum=0;
		for(int i=0;i<weight.length;i++){
			sum+=weight[i];
		}
		if(sum==n){
			boolean tag = true;
			for(int j=weight.length-1;j>=0;j--){
				if(tag && weight[j]!=0){System.out.print(weight[j]);tag=false;continue;}
				if(weight[j] > 0){System.out.print("+" + weight[j]);continue;}
				if(weight[j] < 0)System.out.print(weight[j]);
			}
		}
	}

}



评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值