Luba is surfing the Internet. She currently has n opened tabs in her browser, indexed from 1 to n from left to right. The mouse cursor is currently located at the pos-th tab. Luba needs to use the tabs with indices from l to r (inclusive) for her studies, and she wants to close all the tabs that don't belong to this segment as fast as possible.
Each second Luba can either try moving the cursor to the left or to the right (if the cursor is currently at the tab i, then she can move it to the tab max(i - 1, a) or to the tab min(i + 1, b)) or try closing all the tabs to the left or to the right of the cursor (if the cursor is currently at the tab i, she can close all the tabs with indices from segment [a, i - 1] or from segment [i + 1, b]). In the aforementioned expressions a and b denote the minimum and maximum index of an unclosed tab, respectively. For example, if there were 7 tabs initially and tabs 1, 2 and 7 are closed, then a = 3, b = 6.
What is the minimum number of seconds Luba has to spend in order to leave only the tabs with initial indices from l to r inclusiveopened?
The only line of input contains four integer numbers n, pos, l, r (1 ≤ n ≤ 100, 1 ≤ pos ≤ n, 1 ≤ l ≤ r ≤ n) — the number of the tabs, the cursor position and the segment which Luba needs to leave opened.
Print one integer equal to the minimum number of seconds required to close all the tabs outside the segment [l, r].
6 3 2 4
5
6 3 1 3
1
5 2 1 5
0
In the first test Luba can do the following operations: shift the mouse cursor to the tab 2, close all the tabs to the left of it, shift the mouse cursor to the tab 3, then to the tab 4, and then close all the tabs to the right of it.
In the second test she only needs to close all the tabs to the right of the current position of the cursor.
In the third test Luba doesn't need to do anything.
/*
* 某个人打开了n个网页,现在鼠标光标在pos位置,要求以最少的时间关闭(l,r)以外的窗口,若在l上,则可以关闭l以左的所有窗口,在r可关闭r到右边的所有窗口。
思路:
模拟各种情况。*/
/*
* 浏览器有n个标签页,当前鼠标在第pos个标签页上,每一次可以有下面四种操作:
移动到左边一个标签页
移动到右边一个标签页
关掉鼠标所在标签页的所有左边的标签页
关掉鼠标所在标签页的所有右边的标签页
每次操作花费都是1。现在想要关掉除了[l,r]以外的所有标签页,求最小花费。*/
import java.util.*;
import java.math.*;
public class Main{
public static void main(String[] args) {
Scanner sc = new Scanner(System.in);
int n = sc.nextInt();
int pos = sc.nextInt();
int cl = sc.nextInt();
int cr = sc.nextInt();
if (cl == 1 && cr == n)
System.out.println("0");
else if (cl == 1 && pos >= cr)
System.out.println(pos - cr + 1);
else if (cl == 1 && pos < cr)
System.out.println(cr - pos + 1);
else if (cr == n && pos <= 1)
System.out.println(cl - pos + 1);
else if (cr == n && pos > 1)
System.out.println(pos - cl + 1);
else
System.out.println(Math.min(Math.abs(pos - cl) + cr - cl,
Math.abs(pos - cr) + cr - cl) + 2);
}
}