pSort CodeForces - 28B(并查集)
One day n cells of some array decided to play the following game. Initially each cell contains a number which is equal to it’s ordinal number (starting from 1). Also each cell determined it’s favourite number. On it’s move i-th cell can exchange it’s value with the value of some other j-th cell, if |i?-?j|?=?di, where di is a favourite number of i-th cell. Cells make moves in any order, the number of moves is unlimited.
The favourite number of each cell will be given to you. You will also be given a permutation of numbers from 1 to n. You are to determine whether the game could move to this state.
Input
The first line contains positive integer n (1?≤?n?≤?100) — the number of cells in the array. The second line contains n distinct integers from 1 to n — permutation. The last line contains n integers from 1 to n — favourite numbers of the cells.
Output
If the given state is reachable in the described game, output YES, otherwise NO.
Examples
Input
5
5 4 3 2 1
1 1 1 1 1
Output
YES
Input
7
4 3 5 1 2 7 6
4 6 6 1 6 6 1
Output
NO
Input
7
4 2 5 1 3 7 6
4 6 6 1 6 6 1
Output
YES
一開始以為是個數學題,沒想到是個圖論。。
對于這種各個元素之間有聯系的,一定要往圖論上想想,哪怕他不是。。
我們對于一開始可以移動的點,把它們放到一個集合中。處理完之后,判斷前后兩個位置上的點是否在一個集合中。
代碼如下:
努力加油a啊,(o)/~
總結
以上是生活随笔為你收集整理的pSort CodeForces - 28B(并查集)的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: Honeycomb Gym - 1020
- 下一篇: Crazy Diamond CodeFo