#include #include using namespace std; int main() { int n, k; vector> bars; cin >> n >> k; int as[n+1]; for (int i = 0; i < k; i++) { int x, y; cin >> x >> y; bars.push_back(make_pair(x,y)); } for (int i = 1; i <= n; i++) { int a; cin >> a; as[i] = a; } for (auto p : bars) swap(as[p.first],as[p.second]); bars = {}; for (int i = 1; i <= n; i++) { for (int j = i+1; j <= n; j++) { if (as[j] == i) { for (int l = j; l > i; l--) { bars.push_back(make_pair(l-1,l)); swap(as[l-1],as[l]); } } } } cout << bars.size() << endl; for (auto p : bars) cout << p.first << " " << p.second << endl; return 0; }