結果
| 問題 |
No.326 あみだますたー
|
| コンテスト | |
| ユーザー |
ぴろず
|
| 提出日時 | 2015-12-20 21:15:49 |
| 言語 | Java (openjdk 23) |
| 結果 |
WA
|
| 実行時間 | - |
| コード長 | 985 bytes |
| コンパイル時間 | 2,004 ms |
| コンパイル使用メモリ | 82,628 KB |
| 実行使用メモリ | 60,268 KB |
| 最終ジャッジ日時 | 2024-09-17 12:21:24 |
| 合計ジャッジ時間 | 12,151 ms |
|
ジャッジサーバーID (参考情報) |
judge3 / judge2 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| sample | WA * 2 |
| other | AC * 7 WA * 19 |
ソースコード
package no326;
import java.util.ArrayList;
import java.util.Scanner;
public class Main {
public static void main(String[] args) {
Scanner sc = new Scanner(System.in);
int n = sc.nextInt();
int k = sc.nextInt();
int[] p = new int[n];
for(int i=0;i<n;i++) {
p[i] = i + 1;
}
for(int i=0;i<k;i++) {
int x = sc.nextInt() - 1;
int y = sc.nextInt() - 1;
int temp = p[x];
p[x] = p[y];
p[y] = temp;
}
int[] a = new int[n];
for(int i=0;i<n;i++) {
a[i] = sc.nextInt();
}
int[] map = new int[n+1];
for(int i=0;i<n;i++) {
map[a[i]] = i + 1;
}
for(int i=0;i<n;i++) {
p[i] = map[p[i]];
}
ArrayList<Integer> ans = new ArrayList<>();
//insertion sort
for(int i=1;i<n;i++) {
for(int j=i-1;j>=0;j--) {
if (p[j] > p[j+1]) {
int temp = p[j];
p[j] = p[j+1];
p[j+1] = temp;
ans.add(j);
}
}
}
System.out.println(ans.size());
for(int x:ans) {
System.out.println((x + 1) + " " + (x + 2));
}
}
}
ぴろず