結果

問題 No.792 真理関数をつくろう
ユーザー yukarinoki
提出日時 2019-02-23 00:00:23
言語 C++11(廃止可能性あり)
(gcc 13.3.0)
結果
AC  
実行時間 12 ms / 2,000 ms
コード長 1,319 bytes
コンパイル時間 2,326 ms
コンパイル使用メモリ 163,256 KB
実行使用メモリ 6,824 KB
最終ジャッジ日時 2024-11-26 05:45:55
合計ジャッジ時間 3,352 ms
ジャッジサーバーID
(参考情報)
judge1 / judge3
このコードへのチャレンジ
(要ログイン)
ファイルパターン 結果
sample AC * 4
other AC * 22
権限があれば一括ダウンロードができます

ソースコード

diff #

#include <bits/stdc++.h>
using namespace std;

int main(){
    int n; cin >> n;
    int nn = pow(2,n);
    vector<int> v(n);
    string s; s+= "A=";
    bool flag = true, flag2 = true;
    for(int i=0;i<nn;i++){
        int t;
       for(int i=0;i<n;i++) cin >> v[i];
       cin >> t;
       if(t==1){
            if(flag){
                flag = false;
                s+='(';
                for(int i=0;i<n-1;i++){
                    if(v[i]==0) s+="¬";
                    s+="P_";
                    s+=to_string(i+1);
                    s+="∧";
                }
                if(v[n-1]==0) s+="¬";
                s+="P_";
                s+=to_string(n);
                
                s+=')';
            }else{
                s+="∨";
                s+='(';
                for(int i=0;i<n-1;i++){
                    if(v[i]==0) s+="¬";
                    s+="P_";
                    s+=to_string(i+1);
                    s+="∧";
                }
                if(v[n-1]==0) s+="¬";
                s+="P_";
                s+=to_string(n);
                
                s+=')';
            }
       }else if(flag2){
           flag2= false;
       }
    }
    if(flag) cout << "A=⊥" << endl;
    else if(flag2) cout << "A=⊤"<< endl;
    else cout << s << endl;
    return 0;
}
0