time limit per test1 second

memory limit per test256 megabytes

inputstandard input

outputstandard output

In the country there are n cities and m bidirectional roads between them. Each city has an army. Army of the i-th city consists of ai soldiers. Now soldiers roam. After roaming each soldier has to either stay in his city or to go to the one of neighboring cities by at moving along at most one road.

Check if is it possible that after roaming there will be exactly bi soldiers in the i-th city.

Input

First line of input consists of two integers n and m (1 ≤ n ≤ 100, 0 ≤ m ≤ 200).

Next line contains n integers a1, a2, …, an (0 ≤ ai ≤ 100).

Next line contains n integers b1, b2, …, bn (0 ≤ bi ≤ 100).

Then m lines follow, each of them consists of two integers p and q (1 ≤ p, q ≤ n, p ≠ q) denoting that there is an undirected road between cities p and q.

It is guaranteed that there is at most one road between each pair of cities.

Output

If the conditions can not be met output single word “NO”.

Otherwise output word “YES” and then n lines, each of them consisting of n integers. Number in the i-th line in the j-th column should denote how many soldiers should road from city i to city j (if i ≠ j) or how many soldiers should stay in city i (if i = j).

If there are several possible answers you may output any of them.

Examples

input

4 4

1 2 6 3

3 5 3 1

1 2

2 3

3 4

4 2

output

YES

1 0 0 0

2 0 0 0

0 5 1 0

0 0 2 1

input

2 0

1 2

2 1

output

NO

【题目链接】:http://codeforces.com/problemset/problem/546/E

【题解】



题意:

每个点上的士兵只能走到相邻的点(只能走一次);

然后问你目标状态能不能达到;

做法:

按照下面这张图的规则建边;

把n个点每个点分成入点和出点两个点;

虚拟一个起点和终点(作为源点和汇点);

入点都和起点连在一起;边权为ai;

出点都和终点连在一起;边权为bi;

然后入点和出点之间接一条边;边权为INF;

如果x和y之间有一条边;

则在x的入点和y的出点之间,以及y的入点以及x的出点之间建INF的边;

然后从起点开始跑最大流;



这样造成的效果是,每个点的士兵都只会到和其距离为1的点(然后进入汇点)

显然∑ai==∑bi要满足

这样f[起点][1..i]和f[i+n][汇点]必然都是满流的;

以这个作为判断是否有解的依据;

然后输出每个点到其他点的流量就好;



【完整代码】

#include <bits/stdc++.h>
using namespace std;
#define lson l,m,rt<<1
#define rson m+1,r,rt<<1|1
#define LL long long
#define rep1(i,a,b) for (int i = a;i <= b;i++)
#define rep2(i,a,b) for (int i = a;i >= b;i--)
#define mp make_pair
#define pb push_back
#define fi first
#define se second
#define rei(x) scanf("%d",&x)
#define rel(x) scanf("%I64d",&x) typedef pair<int,int> pii;
typedef pair<LL,LL> pll; const int MAXN = 100+10;
const int dx[9] = {0,1,-1,0,0,-1,-1,1,1};
const int dy[9] = {0,0,0,-1,1,-1,1,-1,1};
const double pi = acos(-1.0); int n,m,s,t;
int g[MAXN*2][MAXN*2],f[MAXN*2][MAXN*2];
int flag[MAXN*2]; int dfs(int x,int m)
{
if (x==t || !m) return m;
if (flag[x]++) return 0;
rep1(y,1,2*n+2)
{
int judge = dfs(y,min(m,g[x][y]-f[x][y]));
if (judge)
{
f[x][y]+=judge;
f[y][x]-=judge;
return judge;
}
}
return 0;
} int main()
{
//freopen("F:\\rush.txt","r",stdin);
rei(n);rei(m);
s = 2*n+1,t = 2*n+2;
rep1(i,1,n)
{
int x;
rei(x);
g[s][i] = x;
}
rep1(i,1,n)
{
int x;
rei(x);
g[i+n][t] = x;
}
rep1(i,1,n)
g[i][i+n] = 100000;
rep1(i,1,m)
{
int x,y;
rei(x);rei(y);
g[x][y+n] = 100000;
g[y][x+n] = 100000;
}
while (dfs(s,100000))
memset(flag,0,sizeof flag);
rep1(i,1,n)
if (f[s][i]!=g[s][i] || f[i+n][t]!=g[i+n][t])
{
puts("NO");
return 0;
}
puts("YES");
rep1(i,1,n)
rep1(j,1,n)
{
printf("%d",f[i][j+n]);
if (j==n)
puts("");
else
putchar(' ');
}
return 0;
}

【codeforces 546E】Soldier and Traveling的更多相关文章

  1. 【codeforces 546D】Soldier and Number Game

    time limit per test3 seconds memory limit per test256 megabytes inputstandard input outputstandard o ...

  2. 【codeforces 546C】Soldier and Cards

    time limit per test2 seconds memory limit per test256 megabytes inputstandard input outputstandard o ...

  3. 【codeforces 546B】Soldier and Badges

    time limit per test3 seconds memory limit per test256 megabytes inputstandard input outputstandard o ...

  4. 【codeforces 546A】Soldier and Bananas

    time limit per test1 second memory limit per test256 megabytes inputstandard input outputstandard ou ...

  5. 网络流(最大流) CodeForces 546E:Soldier and Traveling

    In the country there are n cities and m bidirectional roads between them. Each city has an army. Arm ...

  6. 【CodeForces - 546C】Soldier and Cards (vector或队列)

    Soldier and Cards 老样子,直接上国语吧  Descriptions: 两个人打牌,从自己的手牌中抽出最上面的一张比较大小,大的一方可以拿对方的手牌以及自己打掉的手牌重新作为自己的牌, ...

  7. 【codeforces 415D】Mashmokh and ACM(普通dp)

    [codeforces 415D]Mashmokh and ACM 题意:美丽数列定义:对于数列中的每一个i都满足:arr[i+1]%arr[i]==0 输入n,k(1<=n,k<=200 ...

  8. 【codeforces 707E】Garlands

    [题目链接]:http://codeforces.com/contest/707/problem/E [题意] 给你一个n*m的方阵; 里面有k个联通块; 这k个联通块,每个连通块里面都是灯; 给你q ...

  9. 【codeforces 707C】Pythagorean Triples

    [题目链接]:http://codeforces.com/contest/707/problem/C [题意] 给你一个数字n; 问你这个数字是不是某个三角形的一条边; 如果是让你输出另外两条边的大小 ...

随机推荐

  1. Windows环境下ARM集成开发环境的搭建与使用

    Windows环境下能够使用Eclipse IDE for C/C++ Developers来搭建ARM开发环境 本文地址:http://blog.csdn.net/u011833609/articl ...

  2. 前台Ajax发送数据给后台

    前台发ajax请求给后台 前台代码 let data= [{receiveAdd:receiveAddVal, sendAdd:sendAddVal,distance:distance,goodsNa ...

  3. pt支持的格式

  4. VC++的函数指针和回调函数 及友元函数

    什么是函数指针 函数指针是指向函数的指针变量.也就是说,它是一个指针变量,而且该指针指向一个函数. 对于指针变量来说,它的值是它指向的变量的地址.举个例子:指针变量pi是指向一个整型变量i的指针,则变 ...

  5. [Angular & Web] Retrieve user data from Session

    Once user sign up, we store the user data inside cookie in the broswer and also keep a memory copy i ...

  6. DB2 概览

    2006:IBM公布DB2.9.将数据库领域带入XML时代.IT建设业已进入SOA(Service-Oriented Architecture)时代.实现SOA.其核心难点是顺畅解决不同应用间的数据交 ...

  7. 利用OBJECT_DEFINITION函数来代码存档

    作为一名数据库管理员,在进行代码迁移之前,总是尽力给提交于开发环境的代码一个完整的面貌.但是,不得不承认,我不能保证不发生任何可能破坏开发系统的事情.当这种情况发生时,可能的补救措施是恢复到目标代码的 ...

  8. js课程 4-12 js中正则表达式如何使用

    js课程 4-12 js中正则表达式如何使用 一.总结 一句话总结: 1.js正则表达式手册取哪里找? w3cschool或者菜鸟教程->找到js正则表达式->完整的RegExp参考手册这 ...

  9. 算法 Tricks(三)—— 数组(序列)任意区间最小(大)值

    序列(数组)的区间通过左右端点确定,这样首先设置一个最值变量用来记录最值,从左端点一步步移动到右端点,自然移动的过程中也可以计算整个区间的和,也即一次线性遍历下来,可同时获得多个有用信息. // 区间 ...

  10. C# AutoMapper

    http://www.cnblogs.com/xlhblogs/p/3356748.html