#include<stdio.h>
int main()
{
int i,f[2000],n;
f[1]=2;
for(i=2;i<=1000;i++)
f[i]=f[i-1]+i*(i-1)/2+1;
while(scanf("%d",&n)!=EOF)
{
printf("%d\n",f[n]);
}
return 0;
}
题目解析:
n个平面最多分空间为几个部分的问题首先,可以通过直观想象1-3个平面最多分空间为几个部分。
1个平面最多将空间分为2部分;
2个平面最多将空间分为4部分;
3个平面最多将空间分为8部分;
若要第四个平面将空间分为最多部分,就要它与前三个平面都相交,且交线不重合。则第四个平面与前三个平面都相交,交线不重合,有三条交线,
这三条交线都在第四个平面内,那么【要想使这四个平面分空间为最多部分就要使这三条交线分一个平面为最多部分】。显然,三条直线分一个平面最多
为7部分。所以,四个平面分空间数最多为:三个平面最多分平面数加上三条直线最多分平面的部分数:8+7=15。
推广到一般情况,n个平面最多可分空间为f(n)部分,第n个平面与n-1个平面分别相交且交线不重合,问题转化为n-1条直线最多将一个平面分成几部分。
所以:
f(n)=f(n-1)+n(n+1)/2+1
递归得:
f(n)=(n^3 + 5n + 6)/6
hdu 1290
最新推荐文章于 2020-05-07 17:26:19 发布