Problem G - Switch and Flip
711

G. Switch and Flip

time limit per test: 1 second

memory limit per test: 256 megabytes

input: standard input

output: standard output


There are n coins labeled from 1 to n. Initially, coin ci is on position i and is facing upwards ((c1,c2,…,cn) is a permutation of numbers from 1 to n). You can do some operations on these coins.

In one operation, you can do the following:

  • Choose 2 distinct indices i and j.

  • Then, swap the coins on positions i and j.

  • Then, flip both coins on positions i and j. (If they are initially faced up, they will be faced down after the operation and vice versa)

Construct a sequence of at most n+1 operations such that after performing all these operations the coin i will be on position i at the end, facing up.

Note that you do not need to minimize the number of operations.

Input

The first line contains an integer n (3≤n≤2⋅105) — the number of coins.

The second line contains n integers c1,c2,…,cn (1≤ci≤n, ci≠cj for i≠j).

Output

In the first line, output an integer q (0≤q≤n+1) — the number of operations you used.

In the following q lines, output two integers i and j (1≤i,j≤n,i≠j) — the positions you chose for the current operation.

Examples

input

3
2 1 3

output

3
1 3
3 2
3 1

input

5
1 2 3 4 5

output

0

Note

Let coin i facing upwards be denoted as i and coin i facing downwards be denoted as −i.

The series of moves performed in the first sample changes the coins as such:

[ 2, 1, 3]
[−3, 1,−2]
[−3, 2,−1]
[ 1, 2, 3]

In the second sample, the coins are already in their correct positions so there is no need to swap.

我的作业
去发布

登录后即可发布作业,立即

全部作业

数据加载中...

微信客服

购课补贴
联系客服咨询优惠详情

帮助反馈 APP下载

慕课网APP
您的移动学习伙伴

公众号

扫描二维码
关注慕课网微信公众号