結果

問題 No.397 NO MORE KADOMATSU
コンテスト
ユーザー 💕💖💞
提出日時 2018-06-26 19:21:56
言語 Kotlin
(2.3.20)
コンパイル:
kotlinc _filename_ -include-runtime -d main.jar
実行:
kotlin main.jar
結果
AC  
実行時間 296 ms / 2,000 ms
コード長 648 bytes
記録
記録タグの例:
初AC ショートコード 純ショートコード 純主流ショートコード 最速実行時間
コンパイル時間 11,697 ms
コンパイル使用メモリ 452,864 KB
実行使用メモリ 75,872 KB
平均クエリ数 33.17
最終ジャッジ日時 2026-03-31 04:53:28
合計ジャッジ時間 13,594 ms
ジャッジサーバーID
(参考情報)
judge2_0 / judge3_0
このコードへのチャレンジ
(要ログイン)
ファイルパターン 結果
other AC * 18
権限があれば一括ダウンロードができます
コンパイルメッセージ
Main.kt:14:43: warning: unnecessary non-null assertion (!!) on a non-null receiver of type 'Int'.
    val min = xs.slice(i..xs.size-1).min()!!
                                          ^^

ソースコード

diff #
raw source code

fun main(args:Array<String>) {
  val n = readLine()

  val xs = readLine()!!.split(" ").map( String::toInt ).toMutableList()

  val ans = xs.sorted()

  val res = mutableListOf<Pair<Int,Int>>()
  var i = 0
  while(true) {
    if( i >=  xs.size-1 ) break

    val ta = xs[i]
    val min = xs.slice(i..xs.size-1).min()!!

    if( ta == min ) { i += 1;  continue }

    val tai = xs.slice(i..xs.size-1).lastIndexOf(min) + i
    xs[i]   = min
    xs[tai] = ta

    res.add( Pair(i, tai) )
    i += 1
  }

  //readLine()

  when {
    res.size == 0 -> println(0)
    else -> { println(res.size);  res.map { println("${it.first} ${it.second}") }  }
  }
}
0