CF1266D.Decreasing Debts

普及/提高-

通过率:0%

AC君温馨提醒

该题目为【codeforces】题库的题目,您提交的代码将被提交至codeforces进行远程评测,并由ACGO抓取测评结果后进行展示。由于远程测评的测评机由其他平台提供,我们无法保证该服务的稳定性,若提交后无反应,请等待一段时间后再进行重试。

题目描述

There are nn people in this world, conveniently numbered 11 through nn . They are using burles to buy goods and services. Occasionally, a person might not have enough currency to buy what he wants or needs, so he borrows money from someone else, with the idea that he will repay the loan later with interest. Let d(a,b)d(a,b) denote the debt of aa towards bb , or 00 if there is no such debt.

Sometimes, this becomes very complex, as the person lending money can run into financial troubles before his debtor is able to repay his debt, and finds himself in the need of borrowing money.

When this process runs for a long enough time, it might happen that there are so many debts that they can be consolidated. There are two ways this can be done:

  1. Let d(a,b)>0d(a,b) > 0 and d(c,d)>0d(c,d) > 0 such that aca \neq c or bdb \neq d . We can decrease the d(a,b)d(a,b) and d(c,d)d(c,d) by zz and increase d(c,b)d(c,b) and d(a,d)d(a,d) by zz , where 0<zmin(d(a,b),d(c,d))0 < z \leq \min(d(a,b),d(c,d)) .
  2. Let d(a,a)>0d(a,a) > 0 . We can set d(a,a)d(a,a) to 00 .

The total debt is defined as the sum of all debts:

$$\Sigma_d = \sum_{a,b} d(a,b) $$

Your goal is to use the above rules in any order any number of times, to make the total debt as small as possible. Note that you don't have to minimise the number of non-zero debts, only the total debt.

输入格式

The first line contains two space separated integers nn ( 1n1051 \leq n \leq 10^5 ) and mm ( 0m31050 \leq m \leq 3\cdot 10^5 ), representing the number of people and the number of debts, respectively.

mm lines follow, each of which contains three space separated integers uiu_i , viv_i ( 1ui,vin,uivi1 \leq u_i, v_i \leq n, u_i \neq v_i ), did_i ( 1di1091 \leq d_i \leq 10^9 ), meaning that the person uiu_i borrowed did_i burles from person viv_i .

输出格式

On the first line print an integer mm' ( 0m31050 \leq m' \leq 3\cdot 10^5 ), representing the number of debts after the consolidation. It can be shown that an answer always exists with this additional constraint.

After that print mm' lines, ii -th of which contains three space separated integers ui,vi,diu_i, v_i, d_i , meaning that the person uiu_i owes the person viv_i exactly did_i burles. The output must satisfy 1ui,vin1 \leq u_i, v_i \leq n , uiviu_i \neq v_i and 0<di10180 < d_i \leq 10^{18} .

For each pair iji \neq j , it should hold that uiuju_i \neq u_j or vivjv_i \neq v_j . In other words, each pair of people can be included at most once in the output.

输入输出样例

  • 输入#1

    3 2
    1 2 10
    2 3 5
    

    输出#1

    2
    1 2 5
    1 3 5
    
  • 输入#2

    3 3
    1 2 10
    2 3 15
    3 1 10
    

    输出#2

    1
    2 3 5
    
  • 输入#3

    4 2
    1 2 12
    3 4 8
    

    输出#3

    2
    1 2 12
    3 4 8
    
  • 输入#4

    3 4
    2 3 1
    2 3 2
    2 3 4
    2 3 8
    

    输出#4

    1
    2 3 15
    

说明/提示

In the first example the optimal sequence of operations can be the following:

  1. Perform an operation of the first type with a=1a = 1 , b=2b = 2 , c=2c = 2 , d=3d = 3 and z=5z = 5 . The resulting debts are: d(1,2)=5d(1, 2) = 5 , d(2,2)=5d(2, 2) = 5 , d(1,3)=5d(1, 3) = 5 , all other debts are 00 ;
  2. Perform an operation of the second type with a=2a = 2 . The resulting debts are: d(1,2)=5d(1, 2) = 5 , d(1,3)=5d(1, 3) = 5 , all other debts are 00 .

In the second example the optimal sequence of operations can be the following:

  1. Perform an operation of the first type with a=1a = 1 , b=2b = 2 , c=3c = 3 , d=1d = 1 and z=10z = 10 . The resulting debts are: d(3,2)=10d(3, 2) = 10 , d(2,3)=15d(2, 3) = 15 , d(1,1)=10d(1, 1) = 10 , all other debts are 00 ;
  2. Perform an operation of the first type with a=2a = 2 , b=3b = 3 , c=3c = 3 , d=2d = 2 and z=10z = 10 . The resulting debts are: d(2,2)=10d(2, 2) = 10 , d(3,3)=10d(3, 3) = 10 , d(2,3)=5d(2, 3) = 5 , d(1,1)=10d(1, 1) = 10 , all other debts are 00 ;
  3. Perform an operation of the second type with a=2a = 2 . The resulting debts are: d(3,3)=10d(3, 3) = 10 , d(2,3)=5d(2, 3) = 5 , d(1,1)=10d(1, 1) = 10 , all other debts are 00 ;
  4. Perform an operation of the second type with a=3a = 3 . The resulting debts are: d(2,3)=5d(2, 3) = 5 , d(1,1)=10d(1, 1) = 10 , all other debts are 00 ;
  5. Perform an operation of the second type with a=1a = 1 . The resulting debts are: d(2,3)=5d(2, 3) = 5 , all other debts are 00 .
首页