小红的排列构造
题号:NC269101
时间限制:C/C++/Rust/Pascal 1秒,其他语言2秒
空间限制:C/C++/Rust/Pascal 256 M,其他语言512 M
Special Judge, 64bit IO Format: %lld

题目描述

小红拿到了一个数组,她希望修改尽可能少的元素使其变成排列。你能帮帮她吗?
定义排列为一个长度为n的数组,其中 1 到n每个元素恰好出现一次。

输入描述:

第一行输入一个正整数n,代表数组的大小。
第二行输入n个正整数a_i,用空格隔开。代表数组的元素。
1\leq n\leq 10^5
1\leq a_i \leq 10^9

输出描述:

首先输出一个正整数m,代表操作次数。
接下来的m行,每行输出两个正整数i,x,用空格隔开,代表将第i个元素修改为x
有多种合法方案时,输出任意一种均可。
示例1

输入

复制
4
1 2 3 1

输出

复制
1
1 4

说明

将第一个元素修改为 4 即可。
示例2

输入

复制
3
4 5 6

输出

复制
3
1 2
2 3
3 1