总结:不给数据范围超级差评…
T4
题目大意:a和b轮流出牌,打n轮。每一轮中你点数大分数+3平局分数+1,。给出了你手上有的手牌,以及b的出牌顺序。你要确定自己的出牌顺序,使得自己的总得分最大。牌面大小范围 [ 3 , 13 ] [3,13] [3,13]
数据范围未知。
有个十分显然的费用流模型…
将自己的手牌一列,对方的手牌一列,变成一个二分图模型…然后连 n 2 n^2 n2条边直接跑费用流即可。
有个显然的优化:还是二分图,每边放11个点,代表权值,然后连边方式类似,就能跑 n = 1 e 6 n=1e6 n=1e6的数据范围了。
由于没有Java费用流板子…以下是从网上扒的板子
import java.io.BufferedReader;
import java.io.InputStreamReader;
import java.math.BigDecimal;
import java.math.BigInteger;
import java.util.Arrays;
import java.util.LinkedList;
import java.util.Queue;
import java.util.Scanner;
import java.util.StringTokenizer;
public class zbr01 {
static class InputReader
{
BufferedReader buf;
StringTokenizer tok;
InputReader()
{
buf = new BufferedReader(new InputStreamReader(System.in));
}
boolean hasNext()
{
while(tok == null || !tok.hasMoreElements())
{
try
{
tok = new StringTokenizer(buf.readLine());
}
catch(Exception e)
{
return false;
}
}
return true;
}
String next()
{
if(hasNext()) return tok.nextToken();
return null;
}
int nextInt()
{
return Integer.parseInt(next());
}
long nextLong()
{
return Long.parseLong(next());
}
double nextDouble()
{
return Double.parseDouble(n