結果
| 問題 | No.1083 余りの余り |
| コンテスト | |
| ユーザー |
|
| 提出日時 | 2020-06-19 21:49:54 |
| 言語 | Kotlin (2.3.10) |
| 結果 |
AC
|
| 実行時間 | 505 ms / 3,000 ms |
| コード長 | 1,324 bytes |
| 記録 | |
| コンパイル時間 | 9,055 ms |
| コンパイル使用メモリ | 456,552 KB |
| 実行使用メモリ | 88,412 KB |
| 最終ジャッジ日時 | 2026-03-24 22:35:19 |
| 合計ジャッジ時間 | 19,524 ms |
|
ジャッジサーバーID (参考情報) |
judge2_1 / judge1_0 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| sample | AC * 3 |
| other | AC * 31 |
ソースコード
import java.io.BufferedReader
import java.io.InputStream
import java.io.InputStreamReader
import java.io.PrintWriter
import java.lang.IllegalArgumentException
import java.lang.StringBuilder
import java.util.*
fun PrintWriter.solve(sc: FastScanner) {
val n = sc.nextInt()
val k = sc.nextInt()
val a = Array(n) { sc.nextInt() }
a.sortDescending()
var max = 0
for (i in 0 until 1.shl(n - 1)) {
var v = k
val lst = mutableListOf(n - 1)
for (j in 0 until n - 1) {
if ((1.shl(j) and i) != 0) {
lst.add(j)
}
}
lst.sort()
for (j in lst) {
v %= a[j]
}
max = maxOf(max, v)
}
println(max)
}
fun main(args: Array<String>) {
val writer = PrintWriter(System.out, false)
writer.solve(FastScanner(System.`in`))
writer.flush()
}
class FastScanner(s: InputStream) {
private var st = StringTokenizer("")
private val br = BufferedReader(InputStreamReader(s))
fun next(): String {
while (!st.hasMoreTokens()) st = StringTokenizer(br.readLine())
return st.nextToken()
}
fun nextInt() = next().toInt()
fun nextLong() = next().toLong()
fun nextLine() = br.readLine()
fun nextDouble() = next().toDouble()
fun ready() = br.ready()
}