NYOJ 832合并游戏(状态压缩dp)

2023-12-06 09:32

本文主要是介绍NYOJ 832合并游戏(状态压缩dp),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

描述
大家都知道Yougth除了热爱编程之外,他还有一个爱好就是喜欢玩。
某天在河边玩耍的时候,他发现了一种神奇的石子,当把两个石子放在一起的时候,后一个石子会消失,而且会蹦出一定数量的金币,这可乐坏了Yougth,但是他想得到最多的金币,他该怎么做?
输入
首先一行,一个n(1<=n<=10),表示有n个石子。
接下来n*n的一个矩阵,Aij表示第i个和第j个合并蹦出的金币值(小于10000,注意合并后j会消失)。
输出
输出最多能得到的金币值。
样例输入
2
0 4
1 0
3
0 20 1
12 0 1
1 10 0
样例输出
4

22

 

这一题典型的状态压缩dp, 直接解释状态压缩方程。这题状态压缩方程不好用式子表示,我大概举个例子讲一下怎么转移的。首先要来一个数来表示目前的一个状态,比如n==8,就是有8个石子,然后接着就是假设有一个状态10101101(十进制173),0表示石子已经没掉了,1表示这个石子还在,那么这个状态其实可以由11101101或者10111101或者10101111这三个状态转化而来,而且就这三个, 而这三个状态相比于10101101这个数多出来的1就是相当于与10101101中的1表示的石子合并时没掉的。这个1应该是变成10101101中的0,所以每找到一个0,就枚举这个状态中所有1,因为与可能是这个1让原来的1没掉了,变成了零。以上举了个例子应该就清楚大概思路了清楚了。

 

AC代码:

 

 

# include <cstdio>
# include <cstring>
# include <algorithm>
# include <vector>
using namespace std;
vector<int> v[20];
int bit[20], a[20][20], dp[15000];
int n;
int cal(int temp){int cnt=0;for(int i=1; i<=n; i++){if(!(temp&1)){cnt++;}temp=(temp>>1);}return cnt;
}
int main(){int i, j, k, temp1, l, ans;bit[1]=1;for(i=2; i<=10; i++){bit[i]=(bit[i-1]<<1);}while(scanf("%d", &n)!=EOF){if(n==1){scanf("%d", &temp1);printf("0\n");continue;}memset(dp, 0, sizeof(dp));dp[(1<<n)-1]=0;for(i=0; i<=10; i++){v[i].clear();}for(i=1; i<=n; i++){for(j=1; j<=n; j++){scanf("%d", &a[i][j]);}}for(i=1; i<=(1<<n)-1; i++){v[cal(i)].push_back(i);}for(i=1; i<=n-1; i++){for(j=0; j<=v[i].size()-1; j++){temp1=v[i][j];for(k=1; k<=n; k++){if(!(temp1&1)){for(l=1; l<=n; l++){if(v[i][j]&bit[l]){dp[v[i][j]]=max(dp[v[i][j]], dp[(v[i][j]|bit[k])]+a[l][k]);}}}temp1=(temp1>>1);}}}ans=0;for(i=0; i<=v[n-1].size()-1; i++){ans=max(ans, dp[v[n-1][i]]);}printf("%d\n", ans);}return 0;
}

 

 

 

 

 

这篇关于NYOJ 832合并游戏(状态压缩dp)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

Python实例题之pygame开发打飞机游戏实例代码

《Python实例题之pygame开发打飞机游戏实例代码》对于python的学习者,能够写出一个飞机大战的程序代码,是不是感觉到非常的开心,:本文主要介绍Python实例题之pygame开发打飞机... 目录题目pygame-aircraft-game使用 Pygame 开发的打飞机游戏脚本代码解释初始化部

IIS 7.0 及更高版本中的 FTP 状态代码

《IIS7.0及更高版本中的FTP状态代码》本文介绍IIS7.0中的FTP状态代码,方便大家在使用iis中发现ftp的问题... 简介尝试使用 FTP 访问运行 Internet Information Services (IIS) 7.0 或更高版本的服务器上的内容时,IIS 将返回指示响应状态的数字代

SpringBoot实现文件记录日志及日志文件自动归档和压缩

《SpringBoot实现文件记录日志及日志文件自动归档和压缩》Logback是Java日志框架,通过Logger收集日志并经Appender输出至控制台、文件等,SpringBoot配置logbac... 目录1、什么是Logback2、SpringBoot实现文件记录日志,日志文件自动归档和压缩2.1、

Python中合并列表(list)的六种方法小结

《Python中合并列表(list)的六种方法小结》本文主要介绍了Python中合并列表(list)的六种方法小结,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋... 目录一、直接用 + 合并列表二、用 extend() js方法三、用 zip() 函数交叉合并四、用

利用Python实现Excel文件智能合并工具

《利用Python实现Excel文件智能合并工具》有时候,我们需要将多个Excel文件按照特定顺序合并成一个文件,这样可以更方便地进行后续的数据处理和分析,下面我们看看如何使用Python实现Exce... 目录运行结果为什么需要这个工具技术实现工具的核心功能代码解析使用示例工具优化与扩展有时候,我们需要将

Python实现获取带合并单元格的表格数据

《Python实现获取带合并单元格的表格数据》由于在日常运维中经常出现一些合并单元格的表格,如果要获取数据比较麻烦,所以本文我们就来聊聊如何使用Python实现获取带合并单元格的表格数据吧... 由于在日常运维中经常出现一些合并单元格的表格,如果要获取数据比较麻烦,现将将封装成类,并通过调用list_exc

Python开发文字版随机事件游戏的项目实例

《Python开发文字版随机事件游戏的项目实例》随机事件游戏是一种通过生成不可预测的事件来增强游戏体验的类型,在这篇博文中,我们将使用Python开发一款文字版随机事件游戏,通过这个项目,读者不仅能够... 目录项目概述2.1 游戏概念2.2 游戏特色2.3 目标玩家群体技术选择与环境准备3.1 开发环境3

使用Python实现IP地址和端口状态检测与监控

《使用Python实现IP地址和端口状态检测与监控》在网络运维和服务器管理中,IP地址和端口的可用性监控是保障业务连续性的基础需求,本文将带你用Python从零打造一个高可用IP监控系统,感兴趣的小伙... 目录概述:为什么需要IP监控系统使用步骤说明1. 环境准备2. 系统部署3. 核心功能配置系统效果展

使用Python实现矢量路径的压缩、解压与可视化

《使用Python实现矢量路径的压缩、解压与可视化》在图形设计和Web开发中,矢量路径数据的高效存储与传输至关重要,本文将通过一个Python示例,展示如何将复杂的矢量路径命令序列压缩为JSON格式,... 目录引言核心功能概述1. 路径命令解析2. 路径数据压缩3. 路径数据解压4. 可视化代码实现详解1

SpringBoot使用GZIP压缩反回数据问题

《SpringBoot使用GZIP压缩反回数据问题》:本文主要介绍SpringBoot使用GZIP压缩反回数据问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录SpringBoot使用GZIP压缩反回数据1、初识gzip2、gzip是什么,可以干什么?3、Spr