方块消除 (黑书)

P123

题意: 把一个连续的不同颜色的进行消除,如果颜色相同的N块连在一起,可以一次消除,得分为N*N。然后在这种颜色的两端的方块合拢

           重新连到一起。

比如:1 2 2 2 2 3 3 3 1

最高得分为: 4*4+3*3+2*2=29


这个是看书后自己写的。



#include<iostream>
#include<cstdio>
#include<algorithm>
#include<queue>
#include<vector>
#include<cmath>
#include<set>
#include<cstdlib>
#include<cstring>
#include<stack>
#include<string>

using namespace std;

int color[1111];
int len[1111];
int go[111111];
int n;

int d(int k)
{
	return k*k;
}

int f(int i,int j,int v,int c)
{
	//cout<<i<<' '<<v<<' '<<c<<endl;
	int small=0;
	int k;
	if (i>j)
		return d(v);
	if (i<0)
		return d(v);
	if (i==j)
		return c==color[i]?d(len[i]+v):d(len[i])+d(v);

	for (k=i;k<=j;k++)
	{
		if (c==color[k])
			small=max(small,f(i,k-1,v+len[k],c)+f(k+1,j,0,0));
		else 
			small=max(small,f(i,k-1,len[k],color[k])+d(v)+f(k+1,j,0,0));
	}
	//cout<<small<<endl;
	return small;

}

int main()
{
	freopen("in.txt","r",stdin);
	int i,j,k;
	while (cin>>n,n)
	{
		for (i=0;i<n;i++)
			cin>>go[i];
		k=1;
		color[0]=go[0];
		len[0]=1;
		for (i=1;i<n;i++)
		{
			if (go[i]==go[i-1])
			{
				len[k-1]++;
			}
			else 
			{
				color[k]=go[i];
				len[k]=1;
				k++;
			}
		}

		for (i=0;i<k;i++)
		cout<<i<<' '<<f(0,i,0,0)<<endl;

	}

	return 0;
}


  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值