結果

問題 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;
}
0