ARC089E GraphXY 构造
在Luogu上评了”NOI“之后评级变成了”普及+/提高“……我觉得我可能要退群了
考虑构造一个这样的图:

其中上半部分是从\(S\)开始的一条长\(100\)、每条边权都为\(x\)的链(长度超过\(100\)显然是没有意义的),下半部分是以\(T\)结束的一条长\(100\)、每条边权都为\(y\)的链。在这两条链中间,有\(101 \times 101\)条边(上图中只画出了部分),边权为一个矩阵\(f_{i,j}\)。如果要经过\(f_{i,j}\)对应的边,那么需要从\(S\)开始沿着上半部分的链走\(i\)步,然后经过\(f_{i,j}\),最后沿着下半部分的链走\(j\)步到达\(T\),总边权就是\(xi+yj+f_{i,j}\)。
在这个图中,有\(d_{x,y} = \min\limits_{a,b \geq 0} xa + yb + f_{a,b}\),松弛条件得\(\forall a , b \geq 0 , d_{x,y} \leq xa + yb + f_{a,b}\),即\(f_{a,b} \geq d_{x,y} - xa - yb\)。
这样可以对于每个\(f_{a,b}\)得到\(A \times B\)个不等式,可得\(f_{a,b}\)的解集。而\(f_{a,b}\)一定需要取到其中的最小值(如果不取到最小值,可能存在\(x,y\)满足\(\min\limits_{a,b \geq 0} xa + yb + f_{a,b} > d_{x,y}\)),所以可以得到\(f_{a,b}\)的确切值。然后再代入\(d_{x,y}\)的式子检验以下图是否合法即可。
时间复杂度\(O(N^3)\)
#include<iostream>
#include<cstdio>
#include<cstdlib>
#include<ctime>
#include<cctype>
#include<algorithm>
#include<cstring>
#include<iomanip>
#include<queue>
#include<map>
#include<set>
#include<bitset>
#include<vector>
#include<stack>
#include<cmath>
#include<random>
//This code is written by Itst
using namespace std;
inline int read(){
int a = 0;
char c = getchar();
bool f = 0;
while(!isdigit(c) && c != EOF)
c = getchar();
if(c == EOF)
exit(0);
while(isdigit(c)){
a = a * 10 + c - 48;
c = getchar();
}
return f ? -a : a;
}
int d[12][12] , f[107][107];
signed main(){
int A = read() , B = read();
for(int i = 1 ; i <= A ; ++i)
for(int j = 1 ; j <= B ; ++j)
d[i][j] = read();
for(int i = 0 ; i <= 100 ; ++i)
for(int j = 0 ; j <= 100 ; ++j)
for(int p = 1 ; p <= A ; ++p)
for(int q = 1 ; q <= B ; ++q)
f[i][j] = max(f[i][j] , d[p][q] - i * p - j * q);
for(int i = 1 ; i <= A ; ++i)
for(int j = 1 ; j <= B ; ++j){
int minN = 1e9;
for(int p = 0 ; p <= 100 ; ++p)
for(int q = 0 ; q <= 100 ; ++q)
minN = min(minN , f[p][q] + p * i + q * j);
if(minN != d[i][j]){
puts("Impossible");
return 0;
}
}
puts("Possible");
puts("202 10401");
for(int i = 1 ; i <= 100 ; ++i)
printf("%d %d X\n" , i , i + 1);
for(int i = 102 ; i < 202 ; ++i)
printf("%d %d Y\n" , i , i + 1);
for(int i = 0 ; i <= 100 ; ++i)
for(int j = 0 ; j <= 100 ; ++j)
printf("%d %d %d\n" , 1 + i , 202 - j , f[i][j]);
puts("1 202");
return 0;
}
ARC089E GraphXY 构造的更多相关文章
- 学习笔记:Maven构造版本号的方法解决浏览器缓存问题
需要解决的问题 在做WEB系统开发时,为了提高性能会利用浏览器的缓存功能,其实即使不显式的申明缓存,现代的浏览器都会对静态文件(js.css.图片之类)缓存.但也正因为这个问题导致一个问题,就是资源的 ...
- 一步步构造自己的vue2.0+webpack环境
前面vue2.0和webpack都已经有接触了些(vue.js入门,webpack入门之简单例子跑起来),现在开始学习如何构造自己的vue2.0+webpack环境. 1.首先新建一个目录vue-wk ...
- About 静态代码块,普通代码块,同步代码块,构造代码块和构造函数的纳闷
构造函数用于给对象进行初始化,是给与之对应的对象进行初始化,它具有针对性,函数中的一种.特点:1:该函数的名称和所在类的名称相同.2:不需要定义返回值类型.3:该函数没有具体的返回值.记住:所有对象创 ...
- Eos开发——构造查询条件
1.ajax 方式 var data = { orgid :orgid,year:year ,month: month,type:type,sortField:'sellEmpname' ,sortO ...
- 【C++】类和对象(构造与析构)
类 类是一种抽象和封装机制,描述一组具有相同属性和行为的对象,是代码复用的基本单位. 类成员的访问权限 面向对象关键特性之一就是隐藏数据,采用机制就是设置类成员的访问控制权限.类成员有3种访问权限: ...
- Spring 设值注入 构造注入 p命名空间注入
注入Bean属性---构造注入配置方案 在Spring配置文件中通过<constructor-arg>元素为构造方法传参 注意: 1.一个<constructor-arg>元素 ...
- 并发包的线程池第二篇--Executors的构造
上一篇讲述了ThreadPoolExecutor的执行过程,我们也能看出来一个很明显的问题:这个线程池的构造函数比较复杂,对于不十分理解其运作原理的程序员,自己构造它可能体现和想象中不一样的行为.比如 ...
- 10、代码块、构造代码块、静态代码块及main方法之间的关系
1.普通代码块: 在方法或语句中出现在{}之间的类容就称为普通代码块,简称代码块.普通代码块和一般的语句执行顺序由他们在代码中出现的次序决定--“先出现先执行”,即顺序执行. /*下面第一个类时合法的 ...
- json 构造和解析
目录: (1)引入jar包: (2)json的构造: (3)json的解析: (4)遍历未知key. (1)java对json的处理,可借助org.json.jar. <!-- https:// ...
随机推荐
- Spring基础系列-容器启动流程(1)
原创作品,可以转载,但是请标注出处地址:https://www.cnblogs.com/V1haoge/p/9870339.html 概述 我说的容器启动流程涉及两种情况,SSM开发模式和Spri ...
- BootStrap之 提示工具(Tooltip)插件
<!DOCTYPE html> <html> <head> <meta charset="utf-8"> <title> ...
- 罗汉果与Java虚拟机系列目录与说明
声 明 罗汉果与Java虚拟机系列博文仅为本银结构性整合Java虚拟机知识的笔记和日常JVM问题的DEBUG记录.放到网上主要是为了方便自己今后查看.顺带能帮助到别人就更奈斯了. 目 录 ...
- 前端入门19-JavaScript进阶之闭包
声明 本系列文章内容全部梳理自以下几个来源: <JavaScript权威指南> MDN web docs Github:smyhvae/web Github:goddyZhao/Trans ...
- ArcGIS API for JavaScript 4.2学习笔记[20] 使用缓冲区结合Query对象进行地震点查询【重温异步操作思想】
这个例子相当复杂.我先简单说说这个例子是干啥的. 在UI上,提供了一个下拉框.两个滑动杆,以确定三个参数,使用这三个参数进行空间查询.这个例子就颇带空间查询的意思了. 第一个参数是油井类型,第二个参数 ...
- border,padding,margin盒模型理解
安静的敲着键盘,已势不可挡的姿势逼近php,我想我是一个幸福的人,未来不可期,做好现在,偶尔写着自己能看懂的API,慢慢悠悠的回味一下前端基础知识. 本文盒模型理解. <!DOCTYPE htm ...
- Dynamics 365-Full Text Index on Stopwords
之前写了一篇关于Online Relevance Search的博文,然后又看到罗勇大神关于Full Text Index的博文:Dynamics CRM中一个查找字段引发的[血案],于是准备写点关于 ...
- TCP客户端
TCP通信客户端-解决数据包接收不全的过程 背景:5个串口条码枪,通过MOXA Nport系列转换器,以TCPServer的形式推送扫描到的条码到客户端.5个条码枪均位于流水线上方的支架上,流水线货物 ...
- Android为TV端助力 播放视频卡顿问题
问题分析: 1.连接服务器,ping IP 看看有没有丢包 2.写一个只有mediaplayer的Demo,放到同款的盒子或者电视,保证网咯也是一样的情况下,看看Demo卡不卡 如果一直不卡,那有可能 ...
- mybatis中:selectKey返回最近插入记录的id
<insert id="insert" parameterType="com.lls.model.Employee"> <!-- select ...