首页 > 其他分享 >开心消消乐 题解

开心消消乐 题解

时间:2024-07-26 16:18:13浏览次数:6  
标签:开心 宝石 1145 题解 消消 积分 区间 dp

题目id:8578

题目描述

\(A\)酱最近在玩开心消消乐,由于是异次元的游戏,所以规则可能和地球上的有所不同。
开心消消乐是一个在大圆环上进行的游戏,环上有若干个宝石,每颗宝石都有自己的积分,由于消消乐是一个三消游戏,我们每次可以挑选其中一个宝石消去,消去宝石的积分为他的积分和左右相邻宝石积分的乘积,比如下左图中,消去\(1\)的积分就是\(1×2×4\),如果剩下最后\(2\)颗宝石,比如下图中,消去\(3\)的积分是\(4×3×4\),如果剩下最后\(1\)颗宝石,消去的积分就是他自身的分数。

现在\(A\)酱为了通过这一关,需要将宝石消除完,并且获得的积分越大,她的游戏排名就越高,她想请你帮她算算最大得分是多少。

解题思路

看到这题,第一反应先想到了这题
两题差不多,只要加一个取最大值就可以轻松\(\textcolor[RGB]{82,196,26}{AC}\)此题。
经典的区间\(dp\)模板题,需要考虑环,对于环,我们可以这么考虑:

  • 将\(a\)数组开到原来的\(2\)倍
  • 输入时加一句话a[i+n]=a[i](环形小妙招)

状态转移方程式为\(dp_{i,j}=\max(\)不操作的能量,左区间合并后的能量+右区间合并后的能量+左区间第一个宝石×右区间第一宝石×总区间后面的一个宝石\();\)
如果\(len=n\)的话,则只要考虑\(a_k\)就可以了。

AC Code

#include<bits/stdc++.h>
#define Ios ios::sync_with_stdio(0),cin.tie(nullptr),cout.tie(nullptr)
#define ll long long
using namespace std;
ll n,a[1145],dp[1145][1145],sum[1145],ans=-1145141919810;
int main()
{
    Ios,cin>>n;
    for(int i=1;i<=n;++i)cin>>a[i],a[i+n]=a[i];
    for(int l=1;l<=n;++l)
        for(int i=1,j=l+2;j<=2*n;++j,++i)
            for(int k=i+1;k<j;++k)
            {
                if(l<n)dp[i][j]=max(dp[i][j],dp[i][k]+dp[k][j]+a[i]*a[j]*a[k]);
                else dp[i][j]=max(dp[i][j],dp[i][k]+dp[k][j]+a[k]);
            }
    for(int i=1;i<=n;++i)ans=max(ans,dp[i][i+n+1]);
    cout<<ans;
    return 0;
}

标签:开心,宝石,1145,题解,消消,积分,区间,dp
From: https://www.cnblogs.com/988176-/p/18325633

相关文章

  • CF1988F 较草题解
    \[\begin{aligned}&f_{i,j,k},g_{i,j,k}\to(i\text{permutation},j\text{premaxorsufmax},k(a[l]>a[l-1]))\\&\text{Initialize:}f_{1,1,0}=g_{1,1,0}=1\\&\text{Transferforf,g}\\&f_{i,j,k}=f_{i-1,j-1,k-1......
  • 参天大树 题解
    题目id:5602题目描述丛林中矗立着一棵参天大树,高度为\(y\)。大树\(2\simp\)高度处,每个位置都有一只蚱蜢。一只蚱蜢如果在\(x\)高度处,那么它可以跳到\(2x、3x、4x、......\)等任意一个\(x\)的倍数处。你想在\(2\simy\)高度范围内,找到一个尽可能高且不会有任何蚂蚱能跳到的位......
  • 力扣题解1-两数之和
    LeetCode第一题"两数之和"(TwoSum)问题分析过程:这个问题可以通过多种方法解决,包括暴力解法和使用哈希表的解法。以下是详细的分析过程:暴力解法:遍历数组中的每一对元素,检查它们的和是否等于目标值。时间复杂度是O(n^2),其中n是数组的长度。使用哈希表:使用一......
  • Pag动画:umi+libpag+copy-webpack-plugin实现及问题解决
    1、package.json添加如下,安装依赖:"libpag":"^4.2.84","copy-webpack-plugin":"9.1.0",为什么是写死的旧版本,后面解释2、使用的方法,这里只是一个小示例,具体如何使用看个人(这里主要是想记录过程中出现的问题及解决方式): constinit=async()=>{   constPag......
  • 优美子数列2 题解
    题目id:8628题目描述数学家小\(Q\)得到了一个长度为\(N\)的数列\(a_n\)。小\(Q\)的幸运数字是\(k\),所以他认为,若一个子数列\(a_l,a_{l+1},...,a_r\)的和为\(k\)的倍数,则该子数列是优美子数列。小\(Q\)现在想考考你,\(a_n\)里有多少个优美子数列呢?前置知识前缀和、桶解题思路......
  • 近期题解(2024.7.26)
    CF1070AFindaNumber一个朴素的想法是设\(dp_{x,y}\)表示模\(d\)为\(x\)且和为\(y\)的最小值,那么答案就是\(dp_{0,s}\)。自然初始状态为\(dp_{0,0}=0\),但是我们发现这个转移关系是带环的,所以说要把这个dp换成最短路。直接从\((0,0)\)为源跑一遍bfs即可,时间复......
  • 题解:Codeforces Round 961 (Div. 2) C
    C.Squaringtimelimitpertest:2secondsmemorylimitpertest:256megabytesinput:standardinputoutput:standardoutputikrpprppfoundanarray\(a\)consistingofintegers.Helikesjustice,sohewantstomake\(a\)fair —thatis,makeitnon......
  • 魔术上网导致Github push 443 问题解决方法
    问题描述使用“kexue上网”工具后,在IDEA中push代码到github时,报错:Failedtoconnecttogithub.comport443:Operationtimedout。同时,使用浏览器访问github也会出现无法访问,偶尔能访问的情况。解决办法gitconfig--globalhttp.proxyhttp://127.0.0.1:1087git......
  • 【题解】「CSP模拟赛」雨天 rain
    雨天rain考场上打了一个动态开点线段树,但是被卡空间了......
  • 最小循环节——题解
    最小循环节题目链接题意简述我们需要找到一个字符\(s\)的最短的循环节,对循环节的定义为,当一个字符串\(t\)能够通过若干次自己加自己得到字符串\(s\),我们就称\(t\)是\(s\)的一个循环节。思路简述根据题意,字符串\(s\)本身就是自己的一个循环节。所以,当我们找不到更......