結果

問題 No.2090 否定論理積と充足可能性
ユーザー てろめあ
提出日時 2025-01-19 02:13:42
言語 C++14
(gcc 13.3.0 + boost 1.87.0)
結果
AC  
実行時間 2 ms / 2,000 ms
コード長 787 bytes
コンパイル時間 2,902 ms
コンパイル使用メモリ 175,080 KB
実行使用メモリ 5,248 KB
最終ジャッジ日時 2025-01-19 02:13:47
合計ジャッジ時間 2,932 ms
ジャッジサーバーID
(参考情報)
judge1 / judge4
このコードへのチャレンジ
(要ログイン)
ファイルパターン 結果
other AC * 20
権限があれば一括ダウンロードができます

ソースコード

diff #
プレゼンテーションモードにする

#include<bits/stdc++.h>
using namespace std;
//nand
bool nand(bool a, bool b) {
if (!(a && b)) return true;
else return false;
}
int main(){
map<string, vector<int>> MAP;
vector<string> Alist; //
for (int i = 0; i < 6; i++) {
string A_n;
cin >> A_n;
if(MAP[A_n].empty()) Alist.push_back(A_n);
MAP[A_n].push_back(i);
}
int m = Alist.size(); //
//bit
for (int i = 0; i < (1<<m); i++) {
vector<bool> P_n(6, false);
for (int j = 0; j < m; j++) {
if (i & (1<<j)) {
for (int n : MAP[Alist.at(j)]) P_n[n] = true;
}
}
if (nand(nand(nand(P_n[0], P_n[1]), P_n[2]), nand(nand(P_n[3], P_n[4]), P_n[5]))) {
cout << "YES" << endl;
return 0;
}
}
cout << "NO" << endl;
}
הההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההה
XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX
0