网易互娱笔试2021批题解

这篇博客主要分享了作者在网易互娱笔试中遇到的题目,涉及策略优化问题和未知数据范围的挑战。T4题目通过建立费用流模型解决最大得分问题,使用二分图进行优化能应对更大规模数据。T3题目要求求解数组中子区间的最小乘积的最大值,而T2/T1部分未给出详细解答。
摘要由CSDN通过智能技术生成

总结:不给数据范围超级差评…

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
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值