http://acm.timus.ru/problem.aspx?space=1&num=1900

题目大意:

有N个车站,相邻车站之间形成一个段,这样就有N-1个段,每个段最多可以放一个洗脑的仪器,这样的话,所有经过这个段(放了仪器)的

人都会开心,我们有K个仪器,问怎么放可以让最多的人快乐

思路:

dp[i][j] 代表第i个仪器放在第j个段上的最优值,更新最优值时,需要枚举上一个仪器放的位置,在知道上一个仪器放的位置的情况下,可以

知道当前位置仪器可以作用到多少人。

注意人数全为0的情况

代码:

#include<iostream>
#include<stack>
#include<cstdio>
#include<queue>
#include<cstring>
#include<algorithm>
#include<vector>
#include<set>
#include<map>
#include<string>
#include<cmath> using namespace std; typedef long long ll;
typedef pair<int,int> pp;
const int INF=0x3f3f3f3f;
const int N=503;
int d[N][N];
short int f[N][N];
short int a[N][N];
int b[N][N];
int main()
{
//freopen("data.in","r",stdin);
int n,k;
cin>>n>>k;
memset(a,0,sizeof(a));
memset(b,0,sizeof(b));
for(int i=1;i<n;++i)
for(int j=i+1;j<=n;++j)
cin>>a[i][j];
for(int j=1;j<n;++j)
for(int i=j;i<n;++i)
{
b[i][j]=b[i-1][j];
for(int l=j;l<i;++l)
b[i][j]-=a[l][i];
for(int l=i+1;l<=n;++l)
b[i][j]+=a[i][l];
}
memset(d,-1,sizeof(d));
d[0][0]=0;
memset(f,-1,sizeof(f));
for(int i=0;i<k;++i)
for(int j=i;j<n;++j)
if(d[i][j]!=-1)
for(int l=j+1;l<n;++l)
if(d[i][j]+b[l][j+1]>d[i+1][l])
{
d[i+1][l]=d[i][j]+b[l][j+1];
f[i+1][l]=j;
}
int x=k,y,ans=-1;
for(int j=k;j<n;++j)
if(d[k][j]>ans)
{ans=d[k][j];y=j;}
vector<int>vt;
while(x!=0)
{
vt.push_back(y);
y=f[x][y];
--x;
}
sort(vt.begin(),vt.end());
cout<<ans<<endl;
for(unsigned int i=0;i<vt.size();++i)
{
if(i>0) cout<<" ";
cout<<vt[i];
}
cout<<endl;
return 0;
}

最新文章

  1. .NET面试题系列[14] - LINQ to SQL与IQueryable
  2. Navicat for MySQL 工具注册码
  3. SpringRMI解析3-RmiServiceExporter逻辑细节
  4. javascript中的 类初始化,遍历for in 以及with的用法
  5. emplace_back减少内存拷贝和移动
  6. Android调试工具及方法
  7. JAVA虚拟机简介
  8. java四种创建对象的方法
  9. asm_c515c.uew
  10. linux下文件和目录的颜色表示
  11. HDU1284--完全背包
  12. Java Arrays 源码 笔记
  13. java多线程(4)---volatile关键字
  14. HOG feature
  15. bzoj千题计划188:bzoj1923: [Sdoi2010]外星千足虫 (高斯—若尔当消元法解异或方程组)
  16. 从C++到java
  17. Java 8 Lambda排序 : Comparator example
  18. 国内maven库
  19. 目标反射回波检测算法及其FPGA实现(准备篇): 用Verilog-HDL状态机控制硬件接口
  20. [zabbix] zabbix数据采集频率、数据连续多次异常触发、告警次数、告警频率

热门文章

  1. Java 可变参数列表
  2. python3.4学习笔记(十三) 网络爬虫实例代码,使用pyspider抓取多牛投资吧里面的文章信息,抓取政府网新闻内容
  3. linux上使用amoeba实现MySql集群,以及读写分离,主从复制
  4. 【转】Struts1.x系列教程(2):简单的数据验证
  5. shiro 从入门到放弃
  6. sftp 设置仅能访问自己目录的用户
  7. Android study first ----------安卓项目目录结构及adb指令
  8. Swift基础语法学习总结
  9. Hibernate &lt;查询缓存&gt;
  10. 跨站脚本 XSS&lt;一:介绍&gt;