zoj 3537 cake 切蛋糕 区间DP+凸包+递归 最优三角形剖分

原创 2013年12月05日 23:09:48

题意:给出一些点表示多边形蛋糕的定点的位置(如果蛋糕是凹多边形就不能切),切蛋糕时每次只能在顶点和顶点间切,每一次切蛋糕都有相应的代价,给出代价的公式,问把蛋糕切成多个三角形的最小代价是多少

由于有可能是凹多边形,所以得先判断凸性,直接求凸包,然后判断凸包顶点和所给点的大小,然后再解决最小代价。

最小代价,其实就是最优三角形剖分,小白上有提到。

我用去点的思路yy了好几天,越想越复杂,于是网上看了一下,发现原来是按边操作orz,改完后终于过了,好感动TAT.

我们用dp[i][j]表示从i点到j点所构成的多边形的最优三角剖分,我们以j-i边为三角形的一边,那么三角形的另一个顶点就在i+1到j-1中,这就是区间dp了。当然之前得预处理下各个切刀的代价。

我这边用的是递归,如果想看递推可以去zeroclock大神的博客看看,他的图解很精彩。。

代码:

/*
*  Author:      illuz <iilluzen[at]gmail.com>
*  Blog:        http://blog.csdn.net/hcbbt
*  File:        zoj3537.cpp
*  Create Date: 2013-12-04 16:35:27
*  Descripton:  convex hull + intervel dp 
*/

#include <cstdio>
#include <cstring>
#include <cmath>
#include <algorithm>
using namespace std;

#define sqr(a) ((a) * (a))
#define dis(a, b) sqrt(sqr(a.x - b.x) + sqr(a.y - b.y))

const int MAXN = 305;
const int INF = 0x3c3c3c3c;
const double PI = acos(-1.0);

struct Point {
	double x;
	double y;
	Point(double a = 0, double b = 0) : x(a), y(b) {}
	friend bool operator < (const Point &l, const Point &r) {
		return l.y < r.y || (l.y == r.y && l.x < r.x);
	}
} p[MAXN], ch[MAXN * 2], tmp[MAXN];
// p, point   ch, convex hull

int f[MAXN][MAXN], c[MAXN][MAXN];		// rec and cast
int P;

double mult(const Point &a, const Point &b, const Point &o) {
	return (a.x - o.x) * (b.y - o.y) >= (b.x - o.x) * (a.y - o.y);
}

double Graham(Point p[], int n, Point res[]) {
	int top = 1;
	sort(p, p + n);
	if (n == 0) return 0;
	res[0] = p[0];
	if (n == 1) return 0;
	res[1] = p[1];
	if (n == 2) return dis(p[0], p[1]) * 2;
	res[2] = p[2];
	for (int i = 2; i < n; i++) {
		while (top && (mult(p[i], res[top], res[top - 1])))
			top--;
		res[++top] = p[i];
	}
	int len = top;
	res[++top] = p[n - 2];
	for (int i = n - 3; i >= 0; i--) {
		while (top != len && (mult(p[i], res[top], res[top - 1])))
			top--;
		res[++top] = p[i];
	}
	return top;
}

int calc(int i, int j) {
	return (abs((int)ch[i].x + (int)ch[j].x) * abs((int)ch[i].y + (int)ch[j].y)) % P;
}

int dp(int l, int r) {
	if (f[l][r]) return f[l][r];
	if (r - l <= 2) return 0;
	int ans = INF;
	for (int i = l + 1; i < r; i++) {
		ans = min(ans, dp(l, i) + dp(i, r) + c[l][i] + c[i][r]);
	}
	return f[l][r] = ans;
}

int main() {
	int n;
	while (~scanf("%d%d", &n, &P)) {
		for (int i = 0; i < n; i++)
			scanf("%lf%lf", &p[i].x, &p[i].y);
		if (n <= 3) {
			puts("0");
			continue;
		}
		if (Graham(p, n, ch) < n)
			puts("I can't cut.");
		else {
			memset(f, 0, sizeof(f));
			for (int i = 0; i < n; i++)
				for (int j = i + 2; j < n; j++)
					c[i][j] = c[j][i] = calc(i, j);

			printf("%d\n", dp(0, n - 1));
		}
	}
	return 0;
}


zoj 3537 Cake 【凸包 + 区间dp】 【最优三角剖分】

Cake Time Limit: 1 Second      Memory Limit: 32768 KB You want to hold a party. Here's a pol...
  • chenzhenyu123456
  • chenzhenyu123456
  • 2015年12月23日 12:58
  • 569

zoj3537 Cake 【凸包+最优三角形划分】

判断输入的点能不能组成凸包(即所有点都要是凸包的顶点) 然后就是求最优三角形划分问题,也就是区间dp 感觉这种区间dp还是记忆化搜索写起来比较方便 记忆化搜索#include using namesp...
  • xinag578
  • xinag578
  • 2016年04月06日 11:29
  • 564

zoj3537cake【最优三角剖分+凸包】

几乎就是照着敲的,惭愧ing 说题意,想找论文题没找到,只有浙大的这个比较类似,但是有凸包,本宝宝不开心……简单说一下凸包,“在地上放置一些不可移动的木桩,用一根绳子把他们尽量紧地圈起来,并且为凸边形...
  • zhou_yujia
  • zhou_yujia
  • 2016年02月19日 10:26
  • 608

zoj 3537 cake 切蛋糕 区间DP+凸包+递归 最优三角形剖分

题意:给出一些点表示多边形蛋糕的定点的位置(如果蛋糕是凹多边形就不能切),切蛋糕时每次只能在顶点和顶点间切,每一次切蛋糕都有相应的代价,给出代价的公式,问把蛋糕切成多个三角形的最小代价是多少 由于有可...
  • hcbbt
  • hcbbt
  • 2013年12月05日 23:09
  • 3083

zoj 3537 cake (区间DP+凸包+ 最优三角形剖分模型)

题意:一块多边形先判凸凹,凸则三角剖分 三角剖分模型和最优矩阵链乘模型几乎相同,都是对区间的DP,只不过最优矩阵链乘的最后次乘法决定了决策顺序,三角剖分没天然的顺序,所以要人为加上顺序 凸包用了卷...
  • kalilili
  • kalilili
  • 2015年03月09日 20:54
  • 624

zoj 3537 Cake(区间DP+最优三角形剖分)待续

1、http://acm.zju.edu.cn/onlinejudge/showProblem.do?problemId=4472 2、题目大意; 给出一个多边形,将这个多边形用不相交的线段分割成一个...
  • sdjzping
  • sdjzping
  • 2014年02月10日 16:01
  • 452

Zoj 3537(区间DP)

//呜呜哈哈 我的区间DP的第一道题 // Graham这个凸包函数是直接复制网上的好像是求凸包的个数 //dp[i][j]表示从i到j这个多边形全部分成小三角形所花费的最小费用(不包括边i→j)...
  • u011411189
  • u011411189
  • 2013年11月21日 13:57
  • 625

ZOJ3537 - Cake

Cake Time Limit: 1 Second      Memory Limit: 32768 KB You want to hold a party. Here's a polyg...
  • mowayao
  • mowayao
  • 2014年04月20日 21:22
  • 755

Zoj 3537 Cake (DP最优三角形剖分)

题意:给定n个点的坐标,先问这些点是否能组成一个凸包,如果是凸包,问用不相交的线来切这个凸包使得凸包只由三角形组成,根据costi, j = |xi + xj| * |yi + yj| % p算切线的...
  • qq_21057881
  • qq_21057881
  • 2016年03月27日 20:58
  • 176

Zoj 3537 Cake (DP_最优三角形剖分)

转自:http://blog.csdn.net/woshi250hua/article/details/7824433题目链接:http://acm.zju.edu.cn/onlinejudge/sh...
  • STILLxjy
  • STILLxjy
  • 2016年10月18日 15:24
  • 167
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:zoj 3537 cake 切蛋糕 区间DP+凸包+递归 最优三角形剖分
举报原因:
原因补充:

(最多只允许输入30个字)