思路

题意:此题大意是指首先给你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. 每日一问:Android 滑动冲突,你们都是怎样处理的

    坚持原创日更,短平快的 Android 进阶系列,敬请直接在微信公众号搜索:nanchen,直接关注并设为星标,精彩不容错过. 在 Android 开发中,滑动冲突总是我们一个无法避免的话题.而对于解 ...

  2. o2优化(手动)

    #pragma GCC optimize(2) 将这句话放到程序开头即可

  3. Android使用webService(发送xml数据的方式,不使用jar包)

    Android使用webService可以用ksoap2.jar包来使用.但是我觉得代码不好理解,而且记不住. 所以我查询了好多资料,以及自己的理解.可以用代码发送http请求(发送xml数据)来访问 ...

  4. python小技巧 将二元列表转为一元列表

    list=[num for row in nums for num in row]

  5. Linux C 网络编程——多线程的聊天室实现(服务器端)

    服务器端的主要功能: 实现多用户群体聊天功能(此程序最多设定为10人,可进行更改),每个人所发送的消息其他用户均可以收到.用户可以随意的加入或退出(推出以字符串"bye"实现),服 ...

  6. 菜单(menu)

    菜单 menu ——菜单默认隐藏 ——实现菜单的接口: Menu,父接口,用于创建主菜单 SubMenu继承Menu接口,用于创建子菜单 ContextMenu接口继承Menu接口,用于创建上下文菜单 ...

  7. 第二章 jQuery框架使用准备

    window常用属性: History:有关客户访问过的URL的信息 Location: 有关当前url的信息 常用方法: Confirm()将弹出一个确认对话框 open()在页面上弹出一个新的浏览 ...

  8. python 接口测试环境准备

    1.之前用python做appium测试,今天想要尝试下做接口测试 发现在pycharm下,import requests总是报错 : no  model named requests 联想到应该是没 ...

  9. 【Java】You have an error in your SQL syntax ...

    详情如下: You have an error in your SQL syntax; check the manual that corresponds to your MySQL server v ...

  10. Core CLR Host 源码简单分析

    在定制 CLR Host的时候,可以通过调用如下代码,来获取当前需要被宿主的程序调用入口: hr = Host->CreateDelegate( domainId, L"Main,Ve ...