結果
| 問題 | 
                            No.4 おもりと天秤
                             | 
                    
| コンテスト | |
| ユーザー | 
                             nak2yoshi
                         | 
                    
| 提出日時 | 2020-11-07 01:23:25 | 
| 言語 | D  (dmd 2.109.1)  | 
                    
| 結果 | 
                             
                                AC
                                 
                             
                            
                         | 
                    
| 実行時間 | 3 ms / 5,000 ms | 
| コード長 | 512 bytes | 
| コンパイル時間 | 1,225 ms | 
| コンパイル使用メモリ | 174,396 KB | 
| 実行使用メモリ | 6,944 KB | 
| 最終ジャッジ日時 | 2024-06-22 09:49:57 | 
| 合計ジャッジ時間 | 1,896 ms | 
| 
                            ジャッジサーバーID (参考情報)  | 
                        judge4 / judge1 | 
(要ログイン)
| ファイルパターン | 結果 | 
|---|---|
| other | AC * 23 | 
ソースコード
import std;
import core.bitop;
void main()
{
    auto N = readln.strip.to!int;
    auto W = readln.split.to!(int[]);
    bool[10001][100] memo;
    bool solve(int i, int left, int right)
    {
        if (i == N)
            return left == right;
        if (memo[i][left])
            return false;
        memo[i][left] = true;
        return solve(i + 1, left + W[i], right       )
            || solve(i + 1, left,        right + W[i]);
    }
    (solve(0, 0, 0) ? "possible" : "impossible").writeln;
}
            
            
            
        
            
nak2yoshi