区间dp-环形石子合并

传送门icon-default.png?t=N7T8https://www.luogu.com.cn/problem/P1880

相对于弱化版     这里需要注意(不只是因为环形)

  1. 1.环形做法(环成链)
  2. 2.前缀和维护(不太好计算区间和)
  3. 3.memset需要用cstring头文件
  4. 4.对f【0】【0】的操作

文字无力,见代码

#include<iostream>
#include<cstring>//别忘了,因为这个WA一发
using namespace std;
const int N=305;
int f[N][N];
int g[N][N];//分别记录大小数组
int s[N];//前缀和
int a[N];
int minn=1e9;
int maxn=-1e9;
#define inf 0x3f

int main(){
	memset(f,0x3f,sizeof f);//先全部设为最大,这样方便后面操作
	memset(g,0,sizeof g);//不会是负数,0即可
	int n;cin>>n;
	for(int i=1;i<=n;++i){
		cin>>a[i];a[i+n]=a[i];//环成链
	}
	for(int i=1;i<=2*n;++i){
		s[i]=s[i-1]+a[i];f[i][i]=0,g[i][i]=0;//前缀和和前置操作  (f【0】【0】)
	}
	for(int len=2;len<=n;++len){//长度
		for(int i=1;(i+len-1)<=2*n;++i){//起点
			int j=i+len-1;//终点
			for(int k=i;k<j;++k){//从哪里开始分开
				f[i][j]=min(f[i][j],f[i][k]+f[k+1][j]+s[j]-s[i-1]);
				g[i][j]=max(g[i][j],g[i][k]+g[k+1][j]+s[j]-s[i-1]);
                
                minn=min(minn,f[i][i+n-1]);//这里如果没有被操作,将会一直是最大值
                maxn=max(maxn,g[i][i+n-1]);
			}
		}
	}
	cout<<minn<<endl<<maxn;
	
	return 0;
}

相关推荐

  1. 区间DP,LeetCode 1690. 石子游戏 VII

    2024-02-22 08:22:01       47 阅读
  2. 68、石子合并

    2024-02-22 08:22:01       24 阅读
  3. 1274:【例9.18】合并石子

    2024-02-22 08:22:01       49 阅读
  4. DAY_10(区间dp

    2024-02-22 08:22:01       55 阅读

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2024-02-22 08:22:01       94 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-02-22 08:22:01       100 阅读
  3. 在Django里面运行非项目文件

    2024-02-22 08:22:01       82 阅读
  4. Python语言-面向对象

    2024-02-22 08:22:01       91 阅读

热门阅读

  1. MySQL中的高级查询

    2024-02-22 08:22:01       35 阅读
  2. mysql binlog

    2024-02-22 08:22:01       47 阅读
  3. el-date-picker(日期时间选择)那些事

    2024-02-22 08:22:01       51 阅读
  4. uniapp引入微信小程序直播组件

    2024-02-22 08:22:01       60 阅读
  5. uniapp监听TV电视遥控器的红外按键事件

    2024-02-22 08:22:01       48 阅读
  6. 蓝桥杯基础知识点9 stack、queue、priority_queue

    2024-02-22 08:22:01       46 阅读
  7. Hive--删除数据库

    2024-02-22 08:22:01       48 阅读