算法题20 在1到n中选取若干个数,要求如果选了x就不能选2x和3x,问共有多少种选择方案?

来源:互联网 发布:java log4j2 maven 编辑:程序博客网 时间:2024/06/05 17:39

 

例如,n=3时答案为5,这5种选法分别为{}, {1}, {2}, {3}, {2,3}。

解析:

把数字1放在方阵最左下角,然后不断在一个数的右边填上它的两倍,在其上方填上它的三倍。问题就等价地转化为,在方阵中选取若干个格子使得任意两个不相邻,求有多少种选取方案。这是一个经典的带状态压缩的动态规划问题。另外,遇到尚未出现过的数(即除2和3以外的素数)就再开一张新的表,然后用乘法原理把它们各自对应的方案数乘起来就是了。

例如当n=20时,最终答案就等于下面这7张表各自所对应的选取方案数的乘积。

 

 

这题也许还有组合数学方法,但下面这个加强版估计就只能这样做了:如果再给定一些不能选的数,则又有多少种选择方案?

 

原创粉丝点击