【算法题目】编写一个在1,2,…,9(顺序不能变)数字之间插入+或-或什么都不插入,使得计算结果总是100的程序,并输出所有的可能性。...

	public static void main(String[] args) {

		String[] sym = new String[]{"+", "-", ""};
		String[] nums = new String[]{"1", "2", "3", "4", "5", "6", "7", "8", "9"};
		int count = 0;
		int len = sym.length;
		for (int a=0; a<len; a++)
			for (int b=0; b<len; b++)
				for (int c=0; c<len; c++)
					for (int d=0; d<len; d++)
						for (int e=0; e<len; e++)
							for (int f=0; f<len; f++)
								for (int g=0; g<len; g++)
									for (int h=0; h<len; h++){
										String equation = nums[0] + sym[a] + nums[1] + sym[b] + nums[2] + sym[c] + nums[3] 
                                                          + sym[d] + nums[4] + sym[e] + nums[5] + sym[f] + nums[6] + sym[g] + nums[7] + sym[h] + nums[8]; int sum = getSum(equation); if (sum == 10){ System.out.println(equation + " = " + sum); count++; } } System.out.println("一共有 " + count + " 条公式可以计算出来"); } public static int getSum(String equation){ int sum = 0; String[] addArr = equation.split("\\+"); for (String str : addArr){ if (str.indexOf("-") != -1){ String[] minusArr = str.split("\\-"); for (int i=0; i<minusArr.length; i++){ if(i == 0){ sum += Integer.parseInt(minusArr[i]); } else { sum = (sum - Integer.parseInt(minusArr[i])); } } } else { sum += Integer.parseInt(str); } } return sum; }

  

转载于:https://www.cnblogs.com/timjames/p/8657312.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值