結果
| 問題 |
No.401 数字の渦巻き
|
| コンテスト | |
| ユーザー |
💕💖💞
|
| 提出日時 | 2017-09-09 15:39:01 |
| 言語 | Kotlin (2.1.0) |
| 結果 |
AC
|
| 実行時間 | 554 ms / 2,000 ms |
| コード長 | 1,552 bytes |
| コンパイル時間 | 14,398 ms |
| コンパイル使用メモリ | 445,448 KB |
| 実行使用メモリ | 71,404 KB |
| 最終ジャッジ日時 | 2024-11-20 11:57:09 |
| 合計ジャッジ時間 | 28,270 ms |
|
ジャッジサーバーID (参考情報) |
judge5 / judge4 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| other | AC * 30 |
コンパイルメッセージ
Main.kt:1:11: warning: parameter 'args' is never used
fun main( args : Array<String> ) {
^
Main.kt:7:20: warning: parameter 'x' is never used, could be renamed to _
(0..n-1).map { x ->
^
ソースコード
fun main( args : Array<String> ) {
val n = readLine()!!.toInt()
val mm = mutableListOf<MutableList<Int?>>()
(0..n-1).map { y ->
mm.add( mutableListOf<Int?>() )
(0..n-1).map { x ->
mm[y].add( null )
}
}
// scan
var sX = 0
var sY = n-1
var sX3 = n-1
var sY3 = 0
var cnt = 1
cont@while(true) {
// 1st
if ( mm[sX].filter{ it == null } != listOf<Int?>() ) {
for( i in (0..mm.size-1) ) {
if( mm[sX][i] == null ) {
mm[sX][i] = cnt
cnt++
continue@cont
}
}
}else if( (0..n-1).map{ mm[it][sY] }.filter { it == null } != listOf<Int?>() ) {
for( i in (0..n-1) ) {
if( mm[i][sY] == null ) {
mm[i][sY] = cnt
cnt++
continue@cont
}
}
}else if ( mm[sX3].filter{ it == null } != listOf<Int?>() ) {
for( i in (mm.size-1 downTo 0) ) {
if( mm[sX3][i] == null ) {
mm[sX3][i] = cnt
cnt++
continue@cont
}
}
}else if( (0..n-1).map{ mm[it][sY3] }.filter { it == null } != listOf<Int?>() ) {
for( i in (mm.size-1 downTo 0) ) {
if( mm[i][sY3] == null ) {
mm[i][sY3] = cnt
cnt++
continue@cont
}
}
} else {
sX += 1
sY -= 1
sX3 -= 1
sY3 += 1
if( mm.flatten().filter{ it == null }.size == 0 ) {
break@cont
}
}
}
mm.map { y ->
y.map { x ->
"%03d".format(x)
}.joinToString(" ")
.let {
println(it)
}
}
}
💕💖💞