結果
| 問題 |
No.8015 アンチローリングハッシュ
|
| ユーザー |
|
| 提出日時 | 2021-04-04 07:46:04 |
| 言語 | Kuin (KuinC++ v.2021.9.17) |
| 結果 |
AC
|
| 実行時間 | 57 ms / 2,000 ms |
| コード長 | 684 bytes |
| コンパイル時間 | 1,960 ms |
| コンパイル使用メモリ | 147,232 KB |
| 実行使用メモリ | 10,368 KB |
| 最終ジャッジ日時 | 2024-09-16 12:23:07 |
| 合計ジャッジ時間 | 3,045 ms |
|
ジャッジサーバーID (参考情報) |
judge1 / judge4 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| sample | AC * 2 |
| other | AC * 21 |
ソースコード
func main()
var a: int :: cui@inputInt()
var b: int :: cui@inputInt()
var map: dict<int, []char> :: #dict<int, []char>
for i(0, 10 ^ 8)
var s: []char :: str(i)
var hash: int :: getHash(s, a, b)
var t: []char :: map.get(hash, &)
if(t <>& null & ^s = ^t)
do cui@print("\{s}\n")
do cui@print("\{t}\n")
ret
end if
do map.add(hash, s)
end for
func getHash(s: []char, a: int, b: int): int
var res: int :: 0
for i(0, ^s - 1)
do res :: (res * a + s[i] $ int) % b
end for
ret res
end func
func str(n: int): []char
var res: []char :: ""
while(n <> 0, skip)
do res :~ ['a'.offset(n % 26)]
do n :/ 26
end while
ret res
end func
end func