Codeforces Round #325 (Div. 2) F. Lizard Era: Beginning meet in the mid
F. Lizard Era: Beginning
Time Limit: 1 Sec
Memory Limit: 256 MB
题目连接
http://codeforces.com/contest/586/problem/F
Description
In the game Lizard Era: Beginning the protagonist will travel with three companions: Lynn, Meliana and Worrigan. Overall the game has n mandatory quests. To perform each of them, you need to take exactly two companions.
The attitude of each of the companions to the hero is an integer. Initially, the attitude of each of them to the hero of neutral and equal to 0. As the hero completes quests, he makes actions that change the attitude of the companions, whom he took to perform this task, in positive or negative direction.
Tell us what companions the hero needs to choose to make their attitude equal after completing all the quests. If this can be done in several ways, choose the one in which the value of resulting attitude is greatest possible.
Input
The first line contains positive integer n (1 ≤ n ≤ 25) — the number of important tasks.
Next n lines contain the descriptions of the tasks — the i-th line contains three integers li, mi, wi — the values by which the attitude of Lynn, Meliana and Worrigan respectively will change towards the hero if the hero takes them on the i-th task. All the numbers in the input are integers and do not exceed 107 in absolute value.
,Ci,即此题的初始分值、每分钟减少的分值、dxy做这道题需要花费的时间。
Output
If there is no solution, print in the first line "Impossible".
Otherwise, print n lines, two characters is each line — in the i-th line print the first letters of the companions' names that hero should take to complete the i-th task ('L' for Lynn, 'M' for Meliana, 'W' for Worrigan). Print the letters in any order, if there are multiple solutions, print any of them.
Sample Input
- 7
0 8 9
5 9 -2
6 -8 -7
9 4 5
-4 -9 9
-4 5 2
-6 8 -7
Sample Output
- LM
MW
LM
LW
MW
LM
LW
HINT
题意
有n个任务,有三个人
每次任务都必须派两个人出去,每个任务都会使得人涨能力值,不同人涨的不一样
然后问你有没有一种方案可以使得所有人最后的能力值都一样
如果有多种方案,请输出可以最后使得能力值最大的一种方案
题解:
meet in the mid,状态存三个量就好了A,A-B,B-C,然后就可以瞎搜了,注意最后要输出方案,所以就直接把中间的过程都状压一下就行了
代码:
- #include<iostream>
- #include<stdio.h>
- #include<map>
- #include<vector>
- using namespace std;
- int mid,n;
- int a[],b[],c[];
- map<pair<int,int> ,pair<int,long long> >H;
- pair<int,long long> ans;
- void dfs1(int step,long long sta,int A,int B,int C)
- {
- if(step==mid+)
- {
- pair<int,long long> temp;
- temp = H[pair<int,int>(A-B,B-C)];
- if(temp.second == )
- H[pair<int,int>(A-B,B-C)] = pair<int,long long>(A,sta);
- else
- H[pair<int,int>(A-B,B-C)] = max(temp,pair<int,long long>(A,sta));
- return;
- }
- dfs1(step+,sta<<|,A,B+b[step],C+c[step]);
- dfs1(step+,sta<<|,A+a[step],B,C+c[step]);
- dfs1(step+,sta<<|,A+a[step],B+b[step],C);
- }
- void dfs2(int step,long long sta,int A,int B,int C)
- {
- if(step==n+)
- {
- pair<int,long long> temp = H[pair<int,int>(B-A,C-B)];
- if(temp.second==)return;
- ans = max(ans,pair<int,long long>(A+temp.first,temp.second<<(n-mid<<)|sta));
- return;
- }
- dfs2(step+,sta<<|,A,B+b[step],C+c[step]);
- dfs2(step+,sta<<|,A+a[step],B,C+c[step]);
- dfs2(step+,sta<<|,A+a[step],B+b[step],C);
- }
- int main()
- {
- ans.first = -;
- scanf("%d",&n);
- for(int i=;i<=n;i++)
- scanf("%d%d%d",&a[i],&b[i],&c[i]);
- mid = (n+)/;
- dfs1(,,,,);
- dfs2(mid+,,,,);
- if(ans.first == -)return puts("Impossible");
- vector<int> Ans;
- for(int i=;i<=n;i++)
- {
- Ans.push_back(ans.second&);
- ans.second>>=;
- }
- for(int i=Ans.size()-;i>=;i--)
- {
- if(Ans[i]==)
- cout<<"LM"<<endl;
- else if(Ans[i]==)
- cout<<"LW"<<endl;
- else
- cout<<"MW"<<endl;
- }
- }
Codeforces Round #325 (Div. 2) F. Lizard Era: Beginning meet in the mid的更多相关文章
- Codeforces Round #325 (Div. 1) D. Lizard Era: Beginning
折半搜索,先搜索一半的数字,记录第一个人的值,第二个人.第三个人和第一个人的差值,开个map哈希存一下,然后另一半搜完直接根据差值查找前一半的答案. 代码 #include<cstdio> ...
- Codeforces Round #485 (Div. 2) F. AND Graph
Codeforces Round #485 (Div. 2) F. AND Graph 题目连接: http://codeforces.com/contest/987/problem/F Descri ...
- Codeforces Round #486 (Div. 3) F. Rain and Umbrellas
Codeforces Round #486 (Div. 3) F. Rain and Umbrellas 题目连接: http://codeforces.com/group/T0ITBvoeEx/co ...
- Codeforces Round #501 (Div. 3) F. Bracket Substring
题目链接 Codeforces Round #501 (Div. 3) F. Bracket Substring 题解 官方题解 http://codeforces.com/blog/entry/60 ...
- Codeforces Round #499 (Div. 1) F. Tree
Codeforces Round #499 (Div. 1) F. Tree 题目链接 \(\rm CodeForces\):https://codeforces.com/contest/1010/p ...
- Codeforces Round #376 (Div. 2)F. Video Cards(前缀和)
题目链接:http://codeforces.com/contest/731/problem/F 题意:有n个数,从里面选出来一个作为第一个,然后剩下的数要满足是这个数的倍数,如果不是,只能减小为他的 ...
- Codeforces Round #271 (Div. 2) F. Ant colony (RMQ or 线段树)
题目链接:http://codeforces.com/contest/474/problem/F 题意简而言之就是问你区间l到r之间有多少个数能整除区间内除了这个数的其他的数,然后区间长度减去数的个数 ...
- Codeforces Round #271 (Div. 2) F题 Ant colony(线段树)
题目地址:http://codeforces.com/contest/474/problem/F 由题意可知,最后能够留下来的一定是区间最小gcd. 那就转化成了该区间内与区间最小gcd数相等的个数. ...
- Codeforces Round #479 (Div. 3) F. Consecutive Subsequence (简单dp)
题目:https://codeforces.com/problemset/problem/977/F 题意:一个序列,求最长单调递增子序列,但是有一个要求是中间差值都是1 思路:dp,O(n)复杂度, ...
随机推荐
- .woff 文件404,配置到web.config
<staticContent> <remove fileExtension=".woff" /> <mimeMap fil ...
- poj2229
很不错的一道题,这里提供两种方法: 方法1:递推: 易知当n为奇数时,f[n]=f[n-1] (n-1的所有方案前面添1,并且没有新的方案): 重点是n为偶数的时候,则拆分方案中,要么有偶数个1,要么 ...
- vijosp1507郁闷的出纳员
一道平衡树实现的名次树,用了treap实现. 1.rand()产生的数可能比INF大,很可能改变树的结构. 2.删除时先递归,然后再删除自己,实现就变得简单多了. 3.因为很多情况树会是空的,所以设了 ...
- JAX-RS入门 二 :运行
上一节,已经成功的定义了一个REST服务,并且提供了具体的实现,不过我们还需要把它运行起来. 在上一节的装备部分,列举了必须的jar(在tomcat中运行)和可选的jar(作为一个独立的应用程序运行) ...
- Crosstool-ng制作交叉编译工具链
Crosstool-ng制作交叉编译工具链 交叉编译器可以用现成的,比如CodeSourcery制作的交叉编译器,也可以自己制作,一般是用kernel+gcc+glibc+binutils的源码包来编 ...
- SharePoint 2013 入门教程--系列文章
转:http://www.cnblogs.com/jianyus/p/3381415.html 以下文章是自己在学习SharePoint的过程中,不断积累和总结的博文,现在总结一个目录,分享给大家.这 ...
- 使用BusyBox制作Linux根文件系统
STEP 1:构建目录结构 创建根文件系统目录,主要包括以下目录/dev /etc /lib /usr /var /proc /tmp /home /root /mnt /bin /sbin ...
- gdi写的2048
//-------------------------------------------[头文件及引用]----------------------------------------------- ...
- SQL注入攻击的种类和防范手段
观察近来的一些安全事件及其后果,安全专家们已经得到一个结论,这些威胁主要是通过SQL注入造成的.虽然前面有许多文章讨论了SQL注入,但今天所讨论的内容也许可帮助你检查自己的服务器,并采取相应防范措施. ...
- NGINX(四)配置解析
前言 nginx配置解析是在初始化ngx_cycle_t数据结构时,首先解析core模块,然后core模块依次解析自己的子模块. 配置解析过程 nginx调用ngx_conf_parse函数进行配置文 ...