Virtual contest is a way to take part in past contest, as close as possible to participation on time. It is supported only ACM-ICPC mode for virtual contests.
If you've seen these problems, a virtual contest is not for you - solve these problems in the archive.
If you just want to solve some problem from a contest, a virtual contest is not for you - solve this problem in the archive.
Never use someone else's code, read the tutorials or communicate with other person during a virtual contest.

No tag edit access

B. Art Union

time limit per test

1 secondmemory limit per test

256 megabytesinput

standard inputoutput

standard outputA well-known art union called "Kalevich is Alive!" manufactures objects d'art (pictures). The union consists of *n* painters who decided to organize their work as follows.

Each painter uses only the color that was assigned to him. The colors are distinct for all painters. Let's assume that the first painter uses color 1, the second one uses color 2, and so on. Each picture will contain all these *n* colors. Adding the *j*-th color to the *i*-th picture takes the *j*-th painter *t*_{ij} units of time.

Order is important everywhere, so the painters' work is ordered by the following rules:

- Each picture is first painted by the first painter, then by the second one, and so on. That is, after the
*j*-th painter finishes working on the picture, it must go to the (*j*+ 1)-th painter (if*j*<*n*); - each painter works on the pictures in some order: first, he paints the first picture, then he paints the second picture and so on;
- each painter can simultaneously work on at most one picture. However, the painters don't need any time to have a rest;
- as soon as the
*j*-th painter finishes his part of working on the picture, the picture immediately becomes available to the next painter.

Given that the painters start working at time 0, find for each picture the time when it is ready for sale.

Input

The first line of the input contains integers *m*, *n* (1 ≤ *m* ≤ 50000, 1 ≤ *n* ≤ 5), where *m* is the number of pictures and *n* is the number of painters. Then follow the descriptions of the pictures, one per line. Each line contains *n* integers *t*_{i1}, *t*_{i2}, ..., *t*_{in} (1 ≤ *t*_{ij} ≤ 1000), where *t*_{ij} is the time the *j*-th painter needs to work on the *i*-th picture.

Output

Print the sequence of *m* integers *r*_{1}, *r*_{2}, ..., *r*_{m}, where *r*_{i} is the moment when the *n*-th painter stopped working on the *i*-th picture.

Examples

Input

5 1

1

2

3

4

5

Output

1 3 6 10 15

Input

4 2

2 5

3 1

5 3

10 1

Output

7 8 13 21

Codeforces (c) Copyright 2010-2017 Mike Mirzayanov

The only programming contests Web 2.0 platform

Server time: May/01/2017 01:49:13 (p1).

Desktop version, switch to mobile version.
User lists

Name |
---|