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]);
}
}
}
}