内存限制:?256?Mb时间限制:?1000?ms
二维平面上有一个点。该点最初所在的位置称之为起点。接下来,该点接受了一串命令,每个命令可以用一个大写字母表示:
R
?表示该点沿 X 轴坐标正方向移动了一个单位;L
?表示该点沿 X 轴坐标负方向移动了一个单位;U
?表示该点沿 Y 轴坐标正方向移动了一个单位;D
?表示该点沿 Y 轴坐标负方向移动了一个单位。执行完这些指令后,该点不一定回到起点。请计算至少需要增加多少条指令,才能让这个点回到起点?如果该点已经到达起点,则输出?0。
LRUD
0
LLUU
4
可以运用初中的知识:
1.平面直角坐标系相当于两个互相垂直的数轴
2.绝对值可以表示距离(表示方法:)
——————————————————————————
L相当于,R相当于,U相当于,D相当于。
操作完上下左右后,最后的答案就是。
#include <bits/stdc++.h>
using namespace std;
int x, y;
int main() {
string s;
cin >> s;
for (int i = 0; i < s.length(); i++) {
if (s[i] == 'R')
x++;
if (s[i] == 'L')
x--;
if (s[i] == 'U')
y++;
if (s[i] == 'D')
y--;
}
cout << abs(0 - x) + abs(0 - y);
return 0;
}