思路

题意:此题大意是指首先给你23个队员的信息,包括他们的名字,能力值,在赛场上的职位。然后给出几个若能满足某两个队员同时在球场上就额外加上一定的值。最后让你从23个队员中选出11个人,使得最终的value最大。

具体思路:由于从样例中可以发现字符串比较多,加之需要进行姓名和姓名、score之间关系的记录,这就用到了map。利用dfs对所有队员进行遍历,具体说明在代码中指出。

AC代码

//#include<bits/stdc++.h>
#include<iostream>
#include<cstdio>
#include<cstring>
#include<string>
#include<map>
#include<algorithm>
using namespace std;
map<string, int> id;
map<string, int> manid;
int def = 4, mid = 4, str = 2, goal = 1;
int sum[6], M, asso[24][24];
int vis[24];
int maxs = 0;
struct Men
{
int value, pos;
};
Men man[24];
void init()
{
string s = "defender";
id[s] = 1;
s = "midfielder";
id[s] = 2;
s = "striker";
id[s] = 3;
s = "goalkeeper";
id[s] = 4;
}
void dfs(int last, int d, int m, int s, int g) //d, m, s, g分别指defenders, midfielders, strikers, goalkeeper,last可以避免重复
{
if(d == 4 && m == 4 && s == 2 && g == 1) //满足条件时
{
int cnt = 0;
for(int i = 0; i < 23; i++)
{
if(vis[i])
{
cnt += man[i].value;
for(int j = i + 1; j < 23; j++)
{
if(vis[j])
{
cnt += asso[i+1][j+1];
}
}
}
}
maxs = max(maxs, cnt); //不断记录所有情况,最后得到最大值
return ;
}
for(int i = last; i < 23; i++)
{
if(vis[i])
continue;
if(man[i].pos == 1 && d >= 4) continue;
if(man[i].pos == 2 && m >= 4) continue;
if(man[i].pos == 3 && s >= 2) continue;
if(man[i].pos == 4 && g >= 1) continue;
vis[i] = 1;
if(man[i].pos == 1)
dfs(i, d+1, m, s, g);
else if(man[i].pos == 2)
dfs(i, d, m+1, s, g);
else if(man[i].pos == 3)
dfs(i, d, m, s+1, g);
else if(man[i].pos == 4)
dfs(i, d, m, s, g+1);
vis[i] = 0;
}
}
int main()
{
// freopen("input.txt", "r", stdin);
// freopen("output.txt", "w", stdout);
init();
string na, p;
int v;
while(cin >> na )
{
cin >> v >> p;
manid.clear();
man[0].value = v;
manid[na] = 1;
man[0].pos = id[p];
memset(sum, 0, sizeof(sum));
sum[id[p]] ++;
for(int i = 1; i < 23; i++)
{
cin >> na >> v >> p;
manid[na] = i + 1;
man[i].value = v;
man[i].pos = id[p];
sum[id[p]] ++;
}
cin >> M;
memset(asso, 0, sizeof(asso));
for(int i = 0; i < M; i++)
{
string s1, s2;
int s;
cin >> s1 >> s2 >> s;
asso[manid[s1]][manid[s2]] = s; //记录s1, s2同时存在时的score值
asso[manid[s2]][manid[s1]] = s;
}
if(sum[1] < 4 || sum[2] < 4 || sum[3] < 2 || sum[4] < 1)
{
cout << "impossible" << endl;
continue;
}
memset(vis, 0, sizeof(vis));
maxs = -0x7ffffff;
dfs(0, 0, 0, 0, 0);
cout << maxs << endl;
} }

Arranging Your Team HDU - 3720 【DFS】的更多相关文章

  1. HDU 6113 度度熊的01世界 【DFS】(2017"百度之星"程序设计大赛 - 初赛(A))

    度度熊的01世界 Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)Total Su ...

  2. 【第40套模拟题】【noip2011_mayan】解题报告【map】【数论】【dfs】

    目录:1.潜伏者 [map] 2.Hankson的趣味题[数论]3.mayan游戏[dfs] 题目: 1. 潜伏者(spy.pas/c/cpp)[问题描述]R 国和S 国正陷入战火之中,双方都互派间谍 ...

  3. Kattis - glitchbot 【DFS】

    Kattis - glitchbot [DFS] 题意 有一个机器人 刚开始在(0, 0),然后给出一个目标点,并且会给出一系列指令,但是其中会有一个指令是错误的.我们需要找出那个指令,并且改成正确的 ...

  4. How far away ? HDU - 2586 【LCA】【RMQ】【java】

    题目大意:求树上任意两点距离. 思路: dis[i]表示i到根的距离(手动选根),则u.v的距离=dis[u]+dis[v]-2*dis[lca(u,v)]. lca:u~v的dfs序列区间里,深度最 ...

  5. 【dfs】P1331 海战

    题目描述 在峰会期间,武装部队得处于高度戒备.警察将监视每一条大街,军队将保卫建筑物,领空将布满了F-2003飞机.此外,巡洋船只和舰队将被派去保护海岸线.不幸的是因为种种原因,国防海军部仅有很少的几 ...

  6. 【dfs】p1731 生日蛋糕

    1441:[例题2]生日蛋搞 [题目描述] 7月17日是Mr.W的生日,ACM-THU为此要制作一个体积为Nπ的M层生日蛋糕,每层都是一个圆柱体.设从下往上数第i(1≤i≤M)层蛋糕是半径为Ri, 高 ...

  7. 【dfs】LETTERS

    1212:LETTERS [题目描述] 给出一个roe×colroe×col的大写字母矩阵,一开始的位置为左上角,你可以向上下左右四个方向移动,并且不能移向曾经经过的字母.问最多可以经过几个字母. [ ...

  8. 洛谷P1605 迷宫【dfs】

    题目背景 迷宫 [问题描述] 给定一个N*M方格的迷宫,迷宫里有T处障碍,障碍处不可通过.给定起点坐标和 终点坐标,问: 每个方格最多经过1次,有多少种从起点坐标到终点坐标的方案.在迷宫 中移动有上下 ...

  9. 【dfs】BZOJ1703-[Usaco2007 Mar]Ranking the Cows 奶牛排名

    [题目大意] 农夫约翰有N(1≤N≤1000)头奶牛,每一头奶牛都有一个确定的独一无二的正整数产奶率.约翰想要让这些奶牛按产奶率从高到低排序,约翰已经比较了M(1≤M≤10000)对奶牛的产奶率,但他 ...

随机推荐

  1. 【小家Spring】老项目迁移问题:@ImportResource导入的xml配置里的Bean能够使用@PropertySource导入的属性值吗?

    #### 每篇一句 > 大师都是偏执的,偏执才能产生力量,妥协是没有力量的.你对全世界妥协了你就是空气.所以若没有偏见,哪来的大师呢 #### 相关阅读 [[小家Spring]详解Propert ...

  2. 一道简单的for循环面试题(数字龙形排序)

    本道题是我从网上见到的,因为是一道很久没做的循环题,自己的思路也是陷入了一些思维陷阱中,后来经过把大脑放空,重新看这道题后,思路立马就出来了. 题目就是完成如下图所示的效果: 我一开始是想着将它按照奇 ...

  3. [原创]自动化部署K8S(v1.10.11)集群

          标准运维实现自动化部署K8S集群主要分两步,第一步是部署gse-agent,拱第二步执行部署. 第一步:部署gse-agent.如下: 第二步:部署k8s集群.主要通过作业平台分为5小步执 ...

  4. 查看http请求的header信息

    1 下载chrome浏览器 chrome浏览器是google开发的一块非常绑定浏览器.chrome浏览器下载地址. 2 通过chrome控制台查看http请求的header信息 2.1 打开chrom ...

  5. 在 .h 和 cpp 中查找 :grep consume ~/test/2016/AMQP-CPP/**/*.cpp ~/test/2016/AMQP-CPP/**/*.h -r

    :grep consume ~/test/2016/AMQP-CPP/**/*.cpp ~/test/2016/AMQP-CPP/**/*.h -r -w "whole" 匹配整个 ...

  6. classpath和classpath*区别

    classpath和classpath*区别: classpath:只会到你的class路径中查找找文件. classpath*:不仅包含class路径,还包括jar文件中(class路径)进行查找. ...

  7. java多线程调用run和不调用run的区别

    当在java程序中创建一个线程的时候,会三种情况: 1,只运行run方法 2,先执行start,再执行run方法 3,只运行start方法 三者的区别如下: 运行方式 区别 只运行run 只运行run ...

  8. 《VR入门系列教程》之14---面向大众的Unity3D

    大众化的游戏引擎--Unity3D     并不是所有VR应用都是游戏,然而现在做VR开发的几乎都会用专业游戏引擎来做,因为游戏引擎既满足了一个引擎的要求又可以方便地制作出高品质的VR应用.一个游戏引 ...

  9. java连接oracle数据库jdbc

    driver = oracle.jdbc.driver.OracleDriver url = jdbc:oracle:thin:@localhost:1521:orcl

  10. spring @Required注解

    以下内容引用自http://wiki.jikexueyuan.com/project/spring/annotation-based-configuration/spring-required-ann ...