## Algorithm

D. End of Exams
time limit per test
1 second
memory limit per test
256 megabytes
input
standard input
output
standard output

Students love to celebrate their holidays. Especially if the holiday is the day of the end of exams!

Despite the fact that Igor K., unlike his groupmates, failed to pass a programming test, he decided to invite them to go to a cafe so that each of them could drink a bottle of... fresh cow milk. Having entered the cafe, the m friends found n different kinds of milk on the menu, that's why they ordered n bottles — one bottle of each kind. We know that the volume of milk in each bottle equals w.

When the bottles were brought in, they decided to pour all the milk evenly among the m cups, so that each got a cup. As a punishment for not passing the test Igor was appointed the person to pour the milk. He protested that he was afraid to mix something up and suggested to distribute the drink so that the milk from each bottle was in no more than two different cups. His friends agreed but they suddenly faced the following problem — and what is actually the way to do it?

Help them and write the program that will help to distribute the milk among the cups and drink it as quickly as possible!

Note that due to Igor K.'s perfectly accurate eye and unswerving hands, he can pour any fractional amount of milk from any bottle to any cup.

Input

The only input data file contains three integers nw and m (1 ≤ n ≤ 50100 ≤ w ≤ 10002 ≤ m ≤ 50), where n stands for the number of ordered bottles, w stands for the volume of each of them and m stands for the number of friends in the company.

Output

Print on the first line "YES" if it is possible to pour the milk so that the milk from each bottle was in no more than two different cups. If there's no solution, print "NO".

If there is a solution, then print m more lines, where the i-th of them describes the content of the i-th student's cup. The line should consist of one or more pairs that would look like "b v". Each such pair means that v (v > 0) units of milk were poured into the i-th cup from bottle b (1 ≤ b ≤ n). All numbers b on each line should be different.

If there are several variants to solve the problem, print any of them. Print the real numbers with no less than 6 digits after the decimal point.

Examples
input
Copy
`2 500 3`
output
Copy
`YES1 333.3333332 333.3333332 166.666667 1 166.666667`
input
Copy
`4 100 5`
output
Copy
`YES3 20.000000 4 60.0000001 80.0000004 40.000000 2 40.0000003 80.0000002 60.000000 1 20.000000`
input
Copy
`4 100 7`
output
Copy
`NO`
input
Copy
`5 500 2`
output
Copy
`YES4 250.000000 5 500.000000 2 500.0000003 500.000000 1 500.000000 4 250.000000`

## Code Examples

### #1 Code Example with C++ Programming

```Code - C++ Programming```

``````#include <bits/stdc++.h>

using namespace std;

int n, w, m, fr[51];
vector<vector<pair<int, double> > > g;

int main() {
scanf("%d %d %d", &n, &w, &m);
int all = n * w;
double one = 1.0 * all / m;

g.resize(m);
double cur, sum = 0;
for(int i = 0, j = -1; j < n && i < m; ++i) {
cur = 0;

if(sum <= 1e-8)
++j, sum = w;
if(j >= n)
break;

while(j < n && cur + 1e-8 < one) {
if(sum == 0)
++j, sum = w;
if(j >= n)
break;

if(one - cur + 1e-8 >= sum) {
++fr[j];
if(fr[j] > 2) {
puts("NO");
return 0;
}

cur += sum;
g[i].push_back({j + 1, sum});
sum = 0;
} else {
++fr[j];
if(fr[j] > 2) {
puts("NO");
return 0;
}

double need = one - cur;
cur += need, sum -= need;
g[i].push_back({j + 1, need});
break;
}
}

if(cur + 1e-8 < one) {
puts("NO");
return 0;
}
}

puts("YES");
for(int i = 0; i < m; ++i, puts(""))
for(int j = 0; j < g[i].size(); ++j)
printf("%s%d %.6lf", j == 0 ? "" : " ", g[i][j].first, g[i][j].second);

return 0;
}``````
Copy The Code &

Input

cmd
2 500 3

Output

cmd
YES
1 333.333333
2 333.333333
2 166.666667 1 166.666667