USACO 2018 January Contest, Platinum Problem 3. Sprinklers
Farmer John has a large field, and he is thinking of planting sweet corn in some part of it. After surveying his field, FJ found that it forms ansquare. The southwest corner is at coordinates , and the northeast corner is at .
At some integer coordinates there are double-headed sprinklers, each one sprinkling both water and fertilizer. A double-heading sprinkler at coordinatessprinkles water on the part of the field north and east of it, and sprinkles fertilizer on the part of the field south and west of it. Formally, it waters all real coordinates for which and , and it fertilizes all real coordinates for which and .
Farmer John wants to plant sweet corn in some axis-aligned rectangle in his field with integer-valued corner coordinates. However, for the sweet corn to grow, all points in the rectangle must be both watered and fertilized by the double-headed sprinklers. And of course the rectangle must have positive area, or Farmer John wouldn’t be able to grow any corn in it!
Help Farmer John determine the number of rectangles of positive area in which he could grow sweet corn. Since this number may be large, output the remainder of this number modulo.
INPUT FORMAT (file sprinklers.in):
The first line of the input consists of a single integer, the size of the field ( ).The next lines each contain two space-separated integers. If these integers are and , where , they denote a sprinkler located at .
It is guaranteed that there is exactly one sprinkler in each column and exactly one sprinkler in each row. That is, no two sprinklers have the same-coordinate, and no two sprinklers have the same -coordinate.
OUTPUT FORMAT (file sprinklers.out):
The output should consist of a single integer: the number of rectangles of positive area which are fully watered and fully fertilized, modulo.
5 0 4 1 1 2 2 3 0 4 3
Problem credits: Dhruv Rohatgi