結果
| 問題 | 
                            No.246 質問と回答
                             | 
                    
| コンテスト | |
| ユーザー | 
                             | 
                    
| 提出日時 | 2015-10-28 00:30:40 | 
| 言語 | Scala(Beta)  (3.6.2)  | 
                    
| 結果 | 
                             
                                CE
                                 
                             
                            
                            (最新)
                                AC
                                 
                             
                            (最初)
                            
                            
                         | 
                    
| 実行時間 | - | 
| コード長 | 669 bytes | 
| コンパイル時間 | 4,822 ms | 
| コンパイル使用メモリ | 228,356 KB | 
| 最終ジャッジ日時 | 2024-11-14 19:22:14 | 
| 合計ジャッジ時間 | 5,399 ms | 
| 
                            ジャッジサーバーID (参考情報)  | 
                        judge2 / judge3 | 
(要ログイン)
コンパイルエラー時のメッセージ・ソースコードは、提出者また管理者しか表示できないようにしております。(リジャッジ後のコンパイルエラーは公開されます)
ただし、clay言語の場合は開発者のデバッグのため、公開されます。
            
            
            
            
            ただし、clay言語の場合は開発者のデバッグのため、公開されます。
コンパイルメッセージ
[31m[31m-- [E040] Syntax Error: Main.scala:35:32 ---------------------------------------[0m[0m
[31m35 |[0m  [33mdef[0m [36mmain[0m([36margs[0m: [35mArray[0m[[35mString[0m]) {
[31m[31m   |[0m                                ^[0m
[31m   |[0m                                '=' expected, but '{' found
1 error found
            
            ソースコード
import scala.annotation.tailrec
import scala.io.StdIn
object Problem246 {
  def question(mid: Int): Int = {
    println("? " + mid)
    StdIn.readInt()
  }
  def answer(result: Int): Unit = {
    println("! " + result)
  }
  def proc(): Int = {
    @tailrec
    def q(min: Int, max: Int): Int = {
      val mid = Math.round((min + max) / 2.0).toInt
      if (min == max) {
        return mid
      }
      question(mid) match {
        case 1 => q(mid, max)
        case 0 => q(min, mid - 1)
      }
    }
    val min = 1
    val max = Math.pow(10, 9).toInt
    q(min, max)
  }
  def main(args: Array[String]) {
    val result = proc()
    answer(result)
  }
}