hdu 1466 计算直线的交点数

又做被zzuli小盆友虐过的DP题 T T。。我好弱。。

这个题纠结了一会的,hdu的PPT上有说这个,但是说的不好,处于看不懂状态。但是隐约知道和之前状态有关。

然后手动模拟了下,比如第N条和其中两条直线重合,那么就有三条直线平行了,那么这三条和其他N-3条直线的交点个数就是,(n-3)*3,然后计算其他N-3条直线状况,发现就是当直线为N-3条时所有的状态,那么加上就好了。

中间用了sort和unique去重。

——搜了下= = 。。别人直接标记了。。。好伟大。。

#include <queue>
#include <stack>
#include <math.h>
#include <time.h>
#include <stdio.h>
#include <stdlib.h>
#include <iostream>
#include <limits.h>
#include <string.h>
#include <string>
#include <algorithm>
#define MID(x,y) ( ( x + y ) >> 1 )
#define L(x) ( x << 1 )
#define R(x) ( x << 1 | 1 )
#define BUG puts("here!!!")

using namespace std;

const int MAX = 300;
int dp[25][MAX];
int len[25];

void init()
{
	memset(dp, 0, sizeof(dp));
	memset(len, 0, sizeof(len));
	len[0] = 1;
	dp[1][0] = 0; len[1] = 1;

	for(int i=2; i<=20; i++)
	{
		int cnt = 0;
		for(int k=0; k<i; k++)
			for(int j=0; j<len[k]; j++)
				dp[i][cnt++] = (i - k)*k + dp[k][j];
		len[i] = cnt;
		sort(dp[i], dp[i]+cnt);
		len[i] = unique(dp[i], dp[i]+cnt) - dp[i];
	}
}
int main()
{
	int n;
	
	init();
	while( ~scanf("%d",&n) )
	{
		printf("%d",dp[n][0]);
		for(int i=1; i<len[n]; i++)		
			printf(" %d",dp[n][i]);
		printf("\n");
	}

return 0;
}


你可能感兴趣的:(hdu 1466 计算直线的交点数)