分治算法解决半数集问题

阅读: 评论:0

分治算法解决半数集问题

分治算法解决半数集问题

一、问题描述:
 给定一个自然数n,由n 开始可以依次产生半数集set(n)中的数如下。
(1) n∈set(n);
(2) 在n 的左边加上一个自然数,但该自然数不能超过最近添加的数的一半;
(3) 按此规则进行处理,直到不能再添加自然数为止。
例如,set(6)={6,16,26,126,36,136}。半数集set(6)中有6 个元素。
注意半数集是多重集。
对于给定的自然数n,计算半数集set(n)中的元素个数。

二、问题分析:

     首先应该明确什么是半数集,半数集就是给定一个数,在这个数的左边添加新的数字,新添加的数字应该小于或等于这个数的第一个数字的一半,所以叫做半数,而由这些数字构成的集合就是半数集,以6为例,6的半数集求解过程如下:

6的左边可以添加1,2,3,而26的左边又可以添加1,而36的左边也可以添加1,因此6的半数集就是6,在求解过程中,要求6的半数集就得先求16,26,36的半数集,因此就构成了递归,由图中可以得到求半数集的公式为

从图中可以看出,不论n为多少,树的第二行总是有n/2个节点,遍历第二行的节点,找到每一个节点的半数集再求和,求和的结果再加上树的顶点1即为所求,代码如下:

三、运行程序

 

#include <stdio.h>
#include <stdlib.h>
//int s[500];
int set(n)
{int i,sum = 1;/* if(s[n] > 0)//防止重复加s[n] = sum;*/for(i=1;i<=n/2;i++)sum += set(i);//s[n] = sum;return sum;
}
int main()
{int n;scanf("%d",&n);printf("%dn",set(n));return 0;
}


 

本文发布于:2024-01-29 14:31:30,感谢您对本站的认可!

本文链接:https://www.4u4v.net/it/170650989315944.html

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。

标签:算法
留言与评论(共有 0 条评论)
   
验证码:

Copyright ©2019-2022 Comsenz Inc.Powered by ©

网站地图1 网站地图2 网站地图3 网站地图4 网站地图5 网站地图6 网站地图7 网站地图8 网站地图9 网站地图10 网站地图11 网站地图12 网站地图13 网站地图14 网站地图15 网站地图16 网站地图17 网站地图18 网站地图19 网站地图20 网站地图21 网站地图22/a> 网站地图23