結果

問題 No.267 トランプソート
ユーザー くわいくわい
提出日時 2015-09-23 10:44:56
言語 Scala(Beta)
(3.4.0)
結果
CE  
(最新)
AC  
(最初)
実行時間 -
コード長 970 bytes
コンパイル時間 5,700 ms
コンパイル使用メモリ 226,888 KB
最終ジャッジ日時 2024-11-14 19:15:30
合計ジャッジ時間 6,354 ms
ジャッジサーバーID
(参考情報)
judge5 / judge1
このコードへのチャレンジ
(要ログイン)
コンパイルエラー時のメッセージ・ソースコードは、提出者また管理者しか表示できないようにしております。(リジャッジ後のコンパイルエラーは公開されます)
ただし、clay言語の場合は開発者のデバッグのため、公開されます。

コンパイルメッセージ
-- [E040] Syntax Error: Main.scala:36:32 ---------------------------------------
36 |  def main(args: Array[String]) {
   |                                ^
   |                                '=' expected, but '{' found
1 error found

ソースコード

diff #

import java.util.Scanner

import scala.util.Sorting

object Problem267 {

  case class Card(kind: String)

  object CardOrdering extends Ordering[Card] {
    def compare(a: Card, b: Card) = {
      val ca = formatComparableFormat(a)
      val cb = formatComparableFormat(b)

      ca compare cb
    }

    def formatComparableFormat(c: Card): Int = {
      val mark: Int = c.kind.splitAt(1)._1 match {
        case "D" => 1
        case "C" => 2
        case "H" => 3
        case "S" => 4
      }
      val number: Int = c.kind.splitAt(1)._2 match {
        case "A" => 1
        case "T" => 10
        case "J" => 11
        case "Q" => 12
        case "K" => 13
        case x => x.toInt
      }
      mark * 100 + number
    }
  }

  def main(args: Array[String]) {
    val sc = new Scanner(System.in)
    val n = sc.nextInt

    val cards = Array.fill(n)(Card(sc.next))
    Sorting.quickSort(cards)(CardOrdering)

    println(cards.map(_.kind).mkString(" "))
  }
}
0