关于线分平面的知识,大概是我们在初中和高中的时候做的最多的了,但是怎么样彻底的掌握这些知识呢?这些知识没有一点难度,只不过就是考虑个递推然后打表查表输出值就行了,所以,对于这谢问题,我结合网站上的资料对他们进行了汇总,大家以后凡是遇到这种类型的题目就可以直接用公式了,不要问公式是怎么推理出来的QAQ,自己脑补吧
直线: |
||
条数 |
最多交点数 |
平面数 |
1 |
0 |
2 |
2 |
1 |
f(1)+2 |
3 |
2 |
f(2)+3 |
4 |
3 |
f(3)+4 |
n |
n-1(该条数的直线前面的直线总条数) |
f(n-1)+增加的平面数=f(n-1)++(交点数+1)=f(n-1)+((n-1)+1) |
平行线: |
|||
对数 |
条数 |
最多交点数 |
平面数 |
1 |
2 |
0 |
3 |
2 |
4 |
4=2*2 |
f(1)+6=f(1)+3*2 |
3 |
6 |
8=4*2 |
f(2)+10=f(2)+5*2 |
4 |
8 |
12=6*2 |
f(3)+14=f(3)+7*2 |
n |
2*n |
单条直线交点数*2=该对平行线前的直线总条数*2=(2*(n-1))*2 |
f(n-1)+单条直线增加的平面数*2=f(n-1)+(交点数+1)*2=f(n-1)+(2*(n-1)+1)*2 |
折线: |
|||
折线数 |
所含直线数 |
最多交点数 |
平面数 |
1 |
2 |
0 |
2 |
2 |
4 |
4=2*2 |
f(1)+5=f(1)+(2*3-1) |
3 |
6 |
8=4*2 |
f(2)+9=f(2)+(2*5-1) |
4 |
8 |
12=6*2 |
f(3)+13=f(3)+(2*7-1) |
n |
2*n |
单条直线交点数*2=该对平行线前的直线总条数*2=(2*(n-1))*2 |
f(n-1)+(单条直线增加的平面数*2-1)=f(n-1)+((交点数+1)*2-1)=f(n-1)+((2*(n-1)+1)*2-1) |
三角形 |
|||
个数 |
交点数 |
增加的平面个数 |
分割平面总数 |
1 |
0 |
1 |
2 |
2 |
2*3 |
3*3-3 |
f(1)+3*3-3 |
3 |
4*3 |
5*3-3 |
f(2)+5*3-3 |
4 |
6*3 |
7*3-3 |
f(3)+7*3-3 |
n |
(n*2-2)*3 |
(2*n-1)*3-3 |
f(n-1)+(2*n-1)*3-3=f(n-1)+6*(n-1) |
代码:
# include<cstdio> # include<iostream> using namespace std; # define MAX 12345 int a[MAX]; void dabiao() { a[0] = 0; a[1] = 2; a[2] = 7; for ( int i = 3;i < MAX;i++ ) { a[i]=a[i-1]+(2*(i-1)+1)*2-1; } } int main(void) { dabiao(); int t;cin>>t; while ( t-- ) { int n;cin>>n; cout<<a[n]<<endl; } return 0; }