
cpp
#include <iostream>
#include <string>
#include <vector>
#include <algorithm>
using namespace std;
/// @brief 计算两点组成的面积,保证 point_left 的横坐标 < point_right 的横坐标
/// @param point_left
/// @param point_right
/// @return
static int area_on_2_point(const pair<int, int> &point_left, const pair<int, int> &point_right)
{
int x_len = point_right.first - point_left.first;
int y_len = abs(point_left.second - 0);
return x_len * y_len;
}
// 计算面积
static void HuaWei_OD_test22(void)
{
int cmd_cnt; // 指令个数
int x_end; // 横坐标终点
vector<pair<int, int>> cmd_vec; // 命令集合
vector<pair<int, int>> pos_vec; // 坐标集合
cin >> cmd_cnt >> x_end;
// 获得命令集合
for (int i = 0; i < cmd_cnt; i++)
{
pair<int, int> tmp;
cin >> tmp.first >> tmp.second;
cmd_vec.push_back(tmp);
}
// 根据命令集合得到坐标集合
// 当前坐标
int current_x = 0;
int current_y = 0;
for (int i = 0; i < cmd_cnt; i++)
{
current_x = cmd_vec[i].first;
current_y += cmd_vec[i].second;
pos_vec.push_back(std::make_pair(current_x, current_y));
}
// 计算面积
int area_sum = 0;
for (int i = 0; i < cmd_cnt - 1; i++)
{
area_sum += area_on_2_point(pos_vec[i], pos_vec[i + 1]);
}
// 构造最后一个点(10,0)
pair<int, int> last_point = {x_end, 0};
area_sum += area_on_2_point(pos_vec[cmd_cnt - 1], last_point);
cout << area_sum << endl;
}
int main()
{
HuaWei_OD_test22();
return 0;
}