大致题意:
有n颗原子,给出一个n*n的矩阵map。map[i][j]=a,则代表第i个原子和第j个相撞,且第j个原子会消失,并且释放出a的能量,现在求释放能量的最大值是多少。
大致思路:
dp[b]表示状态b下的最大能量值,比如b=10,则可以二进制转化为1010,在这里我们把0看作保留这一位的原子,1看作这一位的原子消失。则dp[10]可看作第2,4位的原子消失,其他位的原子保留时能量释放的最大值。
由题意可以得到状态转移方程 dp[i+pw[j]]=max(dp[i]+map[k][j],dp[i+pw[j]]);
这里pw[]为:1,2,4,8……
#include<iostream>
#include<cstring>
#include<cstdio>
using namespace std;
int pw[11]={1,2,4,8,16,32,64,128,256,512,1024};
int map[20][20];
int dp[2000];
int main(){
int i,j,k,ans,n;
while(cin>>n&&n){
for(i=0;i<n;i++){
for(j=0;j<n;j++){
cin>>map[i][j];
}
}
ans=0;
memset(dp,0,sizeof(dp));
for(i=0;i<pw[n];i++){
for(j=0;j<n;j++){
for(k=0;k<n;k++){
if(((i&pw[j])==0)&&((i&pw[k])==0)&&j!=k){
dp[i+pw[j]]=max(dp[i]+map[k][j],dp[i+pw[j]]);
ans=max(ans,dp[i+pw[j]]);
}
}
}
}
cout<<ans<<endl;
}
return 0;
}
分享到:
相关推荐
ZOJ,全称“浙江大学程序在线评测系统”(Zhejiang University Online Judge),是一个提供信息学(算法竞赛)题库及程序评测的网站。以下是关于ZOJ的详细介绍: 一、基本信息 名称:浙江大学程序在线评测系统(ZOJ)...
【压缩包子文件的文件名称列表】仅有一个文件名 "zoj 1002",这很可能是一个C++源代码文件,可能命名为`zoj1002.cpp`或`zoj1002.cc`,用于解决ZOJ 1002题目。通常,这种程序会包含输入输出处理、问题逻辑分析、算法...
【压缩包子文件的文件名称列表】"zoj 源码700"可能是压缩包内的文件夹名称,表示所有源代码都集中在这个文件夹下。用户需要解压后才能查看各个题目对应的源代码文件。 基于以上信息,我们可以深入探讨以下几个知识...
【ZOJ1003 Crashing Balloon】这个问题是一个经典的计算机科学竞赛编程题目,主要涉及动态规划(Dynamic Programming, DP)和贪心算法(Greedy Algorithm)的知识点。在这个问题中,参赛者需要编写程序来模拟气球...
解题报告中的DP思路通常包括状态定义、状态转移方程和边界条件。 4. **贪心算法**:在一些问题中,贪心策略可以找到全局最优解,如霍夫曼编码、活动安排等。理解贪心算法的基本思想及其应用条件是必要的。 5. **...
【压缩包子文件的文件名称列表】:"zoj1027 求串相似度.cpp" 这个文件名揭示了ZOJ1027题目的核心内容可能涉及到字符串的相似度计算。在算法竞赛中,字符串处理是一个常见的主题,可能涉及到的操作包括但不限于编辑...
浙江大学ZOJ题目分类旨在为编程学习者提供一个系统化的训练平台,帮助他们在算法和编程技能上实现质的飞跃。ZOJ平台提供的分类题目包括但不限于基础算法、数据结构、动态规划以及模拟问题等,这些分类覆盖了计算机...
ZOJ,全称为Zhejiang Online Judge,是一个知名的在线编程竞赛平台,主要服务于浙江大学和国内其他高校的学生,提供丰富的算法题目供参赛者练习和比赛。这个压缩包文件名为"ZOJ 700多题源代码",意味着它包含了解决...
【ZOJ代码集合】是一个专为ACM(国际大学生程序设计竞赛)爱好者准备的资源库,其中包含了丰富的算法实现和编程技巧。这个压缩包文件名“ZOJ入门与提高代码集”暗示了它旨在帮助初学者逐步提升编程能力,同时也为有...
zoj 题库 详细解答 解题代码 该资源主要涵盖了 zoj 题库中的各种编程题目,涵盖了基本算法、数据结构、数学运算等多个方面的知识点。下面是对该资源中出现的知识点的详细解释: 1. 第一次 ACM 总结(7th ACM) 该...
Problem Arrangement zoj 3777
【压缩包子文件的文件名称列表】"Acm_Code(zju)"可能包含的是作者在ZOJ上解题的代码集合,每个文件可能对应一个特定的题目。这些代码可以是基础的排序算法实现,如冒泡排序、快速排序;可能是复杂的数据结构操作,如...
状态压缩技巧可以帮助减少枚举的空间,从而提高效率。 #### #1115 Digital Root 这是一道数字处理题目,要求不断对一个数的各位数字求和,直到结果小于10为止。这个问题可以通过模拟的方式来解决,即重复地执行...
《ZOJ 4041问题的正确解法与程序分析》 ZOJ(Zhejiang Online Judge)是一个知名的在线编程竞赛平台,其中的题目编号为4041的题目吸引了众多程序员的关注。本篇文章将深入探讨ZOJ 4041的正确解法,并对提供的源代码...
【标题】"ZOJ-CPP.zip" 是一个包含ZOJ(在线判题系统ZeroJudge)网站上多个C++编程练习解答的压缩包。这个压缩包的名称表明它专注于C++语言,很可能是一个学习资源,旨在帮助初学者理解和解决动态规划问题。 【描述...
ZOJ(Zhejiang Online Judge)是一个著名的在线编程竞赛平台,尤其在ACM(国际大学生程序设计竞赛)领域中有着广泛的影响力。这个“ZOJ题解集合-截至2835”显然是一份包含了大量ZOJ题目解决方案的压缩包,其中涵盖了...
ZOJ(Zhejiang Online Judge)是一个著名的在线编程竞赛平台,主要面向计算机科学与信息技术的学生和爱好者,提供了大量的算法题目供参赛者练习和提交代码。"ZOJ题目答案源码"是一个压缩包文件,其中包含了700多道...
标题中的"ZOJ.gz_ ZOJ_ZOJ 1016_max flow_zoj 1045_zoj.rar" 提到了两个ZOJ(Zhejiang Online Judge)的题目,分别是1016和1045,这两个数字通常代表在线编程竞赛中的题目编号。这些题目通常涉及到算法和数据结构的...
标题“ZOJ1014.zip_zoj code_zoj1004”表明这是一个与ZOJ(ZeroJudge)在线判题系统相关的代码压缩包,其中可能包含了解决ZOJ问题1004的源代码。ZOJ是面向编程爱好者和学生的一个在线编程竞赛平台,它提供了各种算法...