YTU3653: 方盒游戏 动态规划 c++

2023-10-12 17:59

本文主要是介绍YTU3653: 方盒游戏 动态规划 c++,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

目录

题目描述

输入

输出

这是代码,自己都大受震撼

希望再也不要让我遇到这道题!!

 

题目描述

NNN 个方盒摆成一排,每个方盒有自己的颜色,如图所示。连续摆放的同颜色方盒构成一个“大块”

玩家每次点击一个方盒,则该方盒所在大块就会消失。若消失的大块中共有 kkk 个方盒,, 则玩家获得 k×kk \times kk×k 个积分。

请问:给定游戏开始时的状态,玩家可获得的最高积分是多少?

输入

第一行是一个整数 ttt (1≤t≤15)(1 \le t \le 15)(1≤t≤15),表示共有多少组测试数据。每组测试数据又包括两行:
首先是一个整数 nnn (1≤n≤200)(1 \le n \le 200)(1≤n≤200),表示共有多少个方盒; 其次包括 nnn 个整数,表示每个方盒的 颜色。这些整数的取值范围是 [1,n]\left[1, n \right][1,n]。

输出

对每组测试数据,分别输出该组测试数据的序号,以及玩家可以获得的最高积分。

这是代码,自己都大受震撼

#include<iostream>
#include<algorithm>
#include<cstring>
#include<cstdio>
#include<cmath>
using namespace std;struct sbtz
{int color;int len;
};
struct sbtz box[205];
int ans[205][205][205];int sb_box(int start, int end, int lens)
{int t1, t2;if (ans[start][end][lens] > 0)return ans[start][end][lens];t1 = box[end].len + lens;t1 = t1 * t1;if (start == end){ans[start][end][lens] = t1;return ans[start][end][lens];}t1 = t1 + sb_box(start, end - 1, 0);for (int i = end - 1; i >= start; i--){if (box[i].color == box[end].color){t2 = sb_box(start, i, box[end].len + lens) + sb_box(i + 1, end - 1, 0);if (t2 > t1) {t1 = t2;}}}ans[start][end][lens] = t1;return ans[start][end][lens];
}int main()
{int t, n;cin >> t;for (int i = 1; i <= t; i++){cin >> n;int num = 0;cin >> box[num].color;box[num].len = 1;for (int j = 1; j < n; j++){int cc;cin >> cc;if (cc == box[num].color)box[num].len++;else{num++;box[num].len = 1;box[num].color = cc;}}memset(ans, 0, sizeof(ans));cout << "Case " << i << ": " << sb_box(0, num, 0) << endl;}return 0;
}

希望再也不要让我遇到这道题!!

实在是自己做不出来,太菜了,具体参考了这位大佬的文章:动态规划——方盒游戏详解_算法解占位盒游戏_*远方的博客-CSDN博客d

这篇关于YTU3653: 方盒游戏 动态规划 c++的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/197503

相关文章

【C++ Primer Plus习题】13.4

大家好,这里是国中之林! ❥前些天发现了一个巨牛的人工智能学习网站,通俗易懂,风趣幽默,忍不住分享一下给大家。点击跳转到网站。有兴趣的可以点点进去看看← 问题: 解答: main.cpp #include <iostream>#include "port.h"int main() {Port p1;Port p2("Abc", "Bcc", 30);std::cout <<

第10章 中断和动态时钟显示

第10章 中断和动态时钟显示 从本章开始,按照书籍的划分,第10章开始就进入保护模式(Protected Mode)部分了,感觉从这里开始难度突然就增加了。 书中介绍了为什么有中断(Interrupt)的设计,中断的几种方式:外部硬件中断、内部中断和软中断。通过中断做了一个会走的时钟和屏幕上输入字符的程序。 我自己理解中断的一些作用: 为了更好的利用处理器的性能。协同快速和慢速设备一起工作

C++包装器

包装器 在 C++ 中,“包装器”通常指的是一种设计模式或编程技巧,用于封装其他代码或对象,使其更易于使用、管理或扩展。包装器的概念在编程中非常普遍,可以用于函数、类、库等多个方面。下面是几个常见的 “包装器” 类型: 1. 函数包装器 函数包装器用于封装一个或多个函数,使其接口更统一或更便于调用。例如,std::function 是一个通用的函数包装器,它可以存储任意可调用对象(函数、函数

C++11第三弹:lambda表达式 | 新的类功能 | 模板的可变参数

🌈个人主页: 南桥几晴秋 🌈C++专栏: 南桥谈C++ 🌈C语言专栏: C语言学习系列 🌈Linux学习专栏: 南桥谈Linux 🌈数据结构学习专栏: 数据结构杂谈 🌈数据库学习专栏: 南桥谈MySQL 🌈Qt学习专栏: 南桥谈Qt 🌈菜鸡代码练习: 练习随想记录 🌈git学习: 南桥谈Git 🌈🌈🌈🌈🌈🌈🌈🌈🌈🌈🌈🌈🌈�

动态规划---打家劫舍

题目: 你是一个专业的小偷,计划偷窃沿街的房屋。每间房内都藏有一定的现金,影响你偷窃的唯一制约因素就是相邻的房屋装有相互连通的防盗系统,如果两间相邻的房屋在同一晚上被小偷闯入,系统会自动报警。 给定一个代表每个房屋存放金额的非负整数数组,计算你 不触动警报装置的情况下 ,一夜之内能够偷窃到的最高金额。 思路: 动态规划五部曲: 1.确定dp数组及含义 dp数组是一维数组,dp[i]代表

【C++】_list常用方法解析及模拟实现

相信自己的力量,只要对自己始终保持信心,尽自己最大努力去完成任何事,就算事情最终结果是失败了,努力了也不留遗憾。💓💓💓 目录   ✨说在前面 🍋知识点一:什么是list? •🌰1.list的定义 •🌰2.list的基本特性 •🌰3.常用接口介绍 🍋知识点二:list常用接口 •🌰1.默认成员函数 🔥构造函数(⭐) 🔥析构函数 •🌰2.list对象

06 C++Lambda表达式

lambda表达式的定义 没有显式模版形参的lambda表达式 [捕获] 前属性 (形参列表) 说明符 异常 后属性 尾随类型 约束 {函数体} 有显式模版形参的lambda表达式 [捕获] <模版形参> 模版约束 前属性 (形参列表) 说明符 异常 后属性 尾随类型 约束 {函数体} 含义 捕获:包含零个或者多个捕获符的逗号分隔列表 模板形参:用于泛型lambda提供个模板形参的名

软考系统规划与管理师考试证书含金量高吗?

2024年软考系统规划与管理师考试报名时间节点: 报名时间:2024年上半年软考将于3月中旬陆续开始报名 考试时间:上半年5月25日到28日,下半年11月9日到12日 分数线:所有科目成绩均须达到45分以上(包括45分)方可通过考试 成绩查询:可在“中国计算机技术职业资格网”上查询软考成绩 出成绩时间:预计在11月左右 证书领取时间:一般在考试成绩公布后3~4个月,各地领取时间有所不同

6.1.数据结构-c/c++堆详解下篇(堆排序,TopK问题)

上篇:6.1.数据结构-c/c++模拟实现堆上篇(向下,上调整算法,建堆,增删数据)-CSDN博客 本章重点 1.使用堆来完成堆排序 2.使用堆解决TopK问题 目录 一.堆排序 1.1 思路 1.2 代码 1.3 简单测试 二.TopK问题 2.1 思路(求最小): 2.2 C语言代码(手写堆) 2.3 C++代码(使用优先级队列 priority_queue)

poj 2976 分数规划二分贪心(部分对总体的贡献度) poj 3111

poj 2976: 题意: 在n场考试中,每场考试共有b题,答对的题目有a题。 允许去掉k场考试,求能达到的最高正确率是多少。 解析: 假设已知准确率为x,则每场考试对于准确率的贡献值为: a - b * x,将贡献值大的排序排在前面舍弃掉后k个。 然后二分x就行了。 代码: #include <iostream>#include <cstdio>#incl