結果
| 問題 | 
                            No.130 XOR Minimax
                             | 
                    
| コンテスト | |
| ユーザー | 
                             6soukiti29
                         | 
                    
| 提出日時 | 2017-09-06 18:17:05 | 
| 言語 | Nim  (2.2.0)  | 
                    
| 結果 | 
                             
                                AC
                                 
                             
                            
                         | 
                    
| 実行時間 | 77 ms / 5,000 ms | 
| コード長 | 575 bytes | 
| コンパイル時間 | 3,252 ms | 
| コンパイル使用メモリ | 65,932 KB | 
| 実行使用メモリ | 39,524 KB | 
| 最終ジャッジ日時 | 2024-09-12 22:49:00 | 
| 合計ジャッジ時間 | 5,019 ms | 
| 
                            ジャッジサーバーID (参考情報)  | 
                        judge5 / judge3 | 
(要ログイン)
| ファイルパターン | 結果 | 
|---|---|
| sample | AC * 3 | 
| other | AC * 21 | 
コンパイルメッセージ
/home/judge/data/code/Main.nim(1, 26) Warning: imported and not used: 'algorithm' [UnusedImport] /home/judge/data/code/Main.nim(1, 36) Warning: imported and not used: 'math' [UnusedImport]
ソースコード
import sequtils,strutils,algorithm,math
var
    N = stdin.readline.parseInt
    A2 = stdin.readline.split.map(parseInt)
    flag : array[100001, bool]
proc solve(d : int, A : openarray[int]) : int =
    if A.len <= 1 or d == -1:
        return 0
    var
        B = newSeqWith(2, newSeq[int](0))
    for a in A:
        B[((a shr d) and 1)].add(a - (1 shl d))
    if B[0].len == 0:
        return solve(d - 1, B[1])
    elif B[1].len == 0:
        return solve(d - 1, B[0])
    else:
        return (1 shl d) + min(solve(d - 1, B[0]), solve(d - 1, B[1]))
echo solve(29, A2)
            
            
            
        
            
6soukiti29