递归与分治策略的基本思想:
分治法顾名思义就是分而治之。一个问题能够用分治法求解的要素是:
第一,问题能够按照某种方式分解成若干个规模较小、相互独立且与原问题类型相同的子问题;
第二,子问题足够小时可以直接求解;
第三,能够将子问题的解组合成原问题的解;由于分治法要求分解成同类子问题,并允许不断分解,使问题规模不断减小,最终可用已知的方法求解足够小的问题,因此,分治法求解很自然导致一个递归算法。问题描述
给定一个自然数n,由n开始可以依次产生半数集set(n)中的数如下。
(1)n∈set(n);
(2)在n的左边加上一个自然数,但该自然数不能超越最近添加的数的一半;
(3)按此规则进行处理,直到不能再添加自然数为止。
例如,set(6)={6,16,26,126,36,136}。半数集set(6)总共有6个元素 。