题目描述:
绘图机器的绘图笔初始位置在原点(0, 0),机器启动后其绘图笔按下面规则绘制直线:
1)尝试沿着横向坐标轴正向绘制直线,直到给定的终点值E。
2)期间可通过指令在纵坐标轴方向进行偏移,并同时绘制直线,偏移后按规则1 绘制直线;指令的格式为X offsetY,表示在横坐标X 沿纵坐标方向偏移,offsetY为正数表示正向偏移,为负数表示负向偏移。
给定了横坐标终点值E、以及若干条绘制指令,请计算绘制的直线和横坐标轴、以及 X=E 的直线组成图形的面积。
输入描述:
首行为两个整数 N E,表示有N条指令,机器运行的横坐标终点值E。
接下来N行,每行两个整数表示一条绘制指令X offsetY,用例保证横坐标X以递增排序方式出现,且不会出现相同横坐标X。
取值范围:0 < N <= 10000, 0 <= X <= E <=20000, -10000 <= offsetY <= 10000。
输出描述:
一个整数,表示计算得到的面积,用例保证,结果范围在0~4294967295内
示例1
输入:
4 10 1 1 2 1 3 1 4 -2
输出:
12
示例2
输入:
2 4 0 1 2 -2
输出:
4
代码
public class Main {
public static void main(String[] args) {
Scanner in = new Scanner(System.in);
int n = in.nextInt();//指令数
int e = in.nextInt();//终点坐标
int x=0;//实时x坐标
int y=0;//实时y坐标
long sum=0;
for (int i = 0; i < n; i++) {
int a = in.nextInt();//指令x
int b = in.nextInt();//指令y
if(a>e){//指令a>x的情况
sum+= (long) (a - x) *Math.abs(y);
}else{
sum+= (long) (a - x) *Math.abs(y);
x=a;
y=b+y;
}
}
sum+=(long) (e - x) *Math.abs(y);
System.out.println(sum);
}
}