奇怪的捐赠

标题:奇怪的捐赠


    地产大亨Q先生临终的遗愿是:拿出100万元给X社区的居民抽奖,以稍慰藉心中愧疚。
麻烦的是,他有个很奇怪的要求:


1. 100万元必须被正好分成若干份(不能剩余)。每份必须是7的若干次方元。
   比如:1元, 7元,49元,343元,...


2. 相同金额的份数不能超过5份。


3. 在满足上述要求的情况下,分成的份数越多越好!


请你帮忙计算一下,最多可以分为多少份?




注意:只需要填写一个整数,就是分成的份数,不要填写任何多余的内容。比如说明文字。


-----------------------------


剧透中.......


笨笨有话说:
    7的次方能有多少啊?不超过100万的一共就那么几个,每个的取值从0到5,
组合起来也没有多少啊,看看哪个组合刚好凑成100万不就行了。
    如果嫌找出最多的那个组合费事,把所有凑成100万的输出不就行了?我就不信,
能凑成100万的情况会有那么多吗?应该屈指可数吧!    


歪歪有话说:
    如果要求是10的次幂的话,1,10,100,1000,.... 会怎么样?很容易算哦。
那么,10是个特殊的数字吗?难道不是因为我们人类有10个手指吗?

如果我们的手指是7根.......7进制你听说过吗?

 

答案 16

 

//dfs
public class Main {
	static int[] mk = new int[100];
	static int num = 0;

	public static void main(String[] args) {
		dfs(0, 0);
	}

	public static void dfs(int i, int count) {
		if (count > 1000000)
			return;
		if (mk[i] > 5)
			return;
		int temp = 1;
		if (i == 0) {
			count += 1;
			temp = 0;
		}
		for (int j = 0; j < i; j++) {
			temp = temp * 7;
		}
		count += temp;
		mk[i] += 1;
		num += 1;
		if (count == 1000000) {
			System.out.println(num);
			return;
		}
		dfs(i, count);
		dfs(i + 1, count);
		mk[i] -= 1;
		num -= 1;
		count -= temp;
	}
}

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值