結果
問題 | No.326 あみだますたー |
ユーザー |
|
提出日時 | 2016-05-02 21:57:11 |
言語 | Java (openjdk 23) |
結果 |
AC
|
実行時間 | 373 ms / 2,000 ms |
コード長 | 1,329 bytes |
コンパイル時間 | 2,428 ms |
コンパイル使用メモリ | 80,484 KB |
実行使用メモリ | 48,656 KB |
最終ジャッジ日時 | 2024-11-08 00:16:00 |
合計ジャッジ時間 | 10,672 ms |
ジャッジサーバーID (参考情報) |
judge1 / judge4 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 2 |
other | AC * 26 |
ソースコード
package yukicoder;import java.util.ArrayDeque;import java.util.Arrays;import java.util.Scanner;public class Main {public static void main(String[] args)throws Exception{new Main().solve();}void solve(){Scanner sc=new Scanner(System.in);int n=sc.nextInt();int k=sc.nextInt();int[] d=new int[n];for(int i=0;i<n;i++){d[i]=i;}for(int i=0;i<k;i++){int x=sc.nextInt()-1;int y=sc.nextInt()-1;d=Arrays.copyOf(swap(d,x,y), d.length);}//テスト用// tr(d);ArrayDeque<Pair> q=new ArrayDeque<Pair>();int[] ab=new int[n];for(int i=0;i<n;i++){ab[sc.nextInt()-1]=i;}for(int i=0;i<n;i++){int a=ab[i];if(d[i]==a)continue;for(int j=i+1;j<n;j++){if(d[j]==a){a=j;break;}}for(int j=a;j>i;j--){d=Arrays.copyOf(swap(d,j,j-1), d.length);q.addLast(new Pair(j-1,j));}}System.out.println(q.size());while(!q.isEmpty()){Pair p=q.pollFirst();System.out.println((p.a+1)+" "+(p.b+1));}}class Pair{//a<bとするint a;int b;Pair(int a,int b){if(a>b){int d=a;a=b;b=d;}this.a=a;this.b=b;}}int[] swap(int[] d,int a,int b){int dumy=d[a];d[a]=d[b];d[b]=dumy;return d;}void tr(Object...o){System.out.println(Arrays.deepToString(o));}}