码迷,mamicode.com
首页 > 其他好文 > 详细

POJ 3628 Bookshelf 2 题解

时间:2014-06-28 08:11:26      阅读:238      评论:0      收藏:0      [点我收藏+]

标签:blog   使用   数据   2014   name   for   

本题解法很多,因为给出的数据特殊性故此可以使用DFS和BFS,也可以使用01背包DP思想来解。

因为一般大家都使用DFS,这里使用很少人使用的BFS,缺点是比DFS更加耗内存,不过优点是速度比DFS快。

当然也比DFS难写点:

int N, B;
int Height[21];
inline int mMin(int a, int b) { return a > b? b : a; }
inline int mMax(int a, int b) { return a < b? b : a; }

int bfs()
{
	vector<int> vStk;	
	vStk.push_back(0);

	int id = 0;
	int mh = INT_MAX;
	while (id < N)
	{
		for (int i = (int)vStk.size() - 1; i >= 0 ; i--)
		{
			int h = vStk[i] + Height[id];
			if (h >= B) mh = mMin(mh, h-B);
			vStk.push_back(h);
		}//缺点,会消耗大量的内存,最后vector会非常大,优点,速度比dfs快
		id++;
	}
	return mh;
}

int main()
{
	while (scanf("%d %d", &N, &B) != EOF)
	{
		for (int i = 0; i < N; i++)
		{
			scanf("%d", &Height[i]);
		}
		printf("%d\n", bfs());
	}
	return 0;
}





POJ 3628 Bookshelf 2 题解,布布扣,bubuko.com

POJ 3628 Bookshelf 2 题解

标签:blog   使用   数据   2014   name   for   

原文地址:http://blog.csdn.net/kenden23/article/details/35286585

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!