1

我正在尝试将真值表的结果转换回布尔语句。对于不熟悉的人,我将详细写它。

我有一个格式如下的字符串向量。向量内的所有字符串成员都具有相等的长度。成员仅由-or0或组成1。例如向量 v 包含 3 个成员,每个成员的长度为 5。

string vv[] = { "--1-0"  , "-1-1-" ,  "01-1-" };
std::vector<string> v(begin(vv), end(vv));

字符串的每个字符代表另一个向量“A”成员以及一个布尔运算。例如,

第一个--1-0(A[2] && !A[4])

我想将上面的向量v转换为

(A[2] && !A[4]) || (A[1] && A[3] ) || (!A[0] && A[1] && A[3])

我想要做的是有一个带有向量vA作为输入的函数,并且返回高于布尔语句。我相信您已经注意到1is true, 0isNot true-is don't care 状态。

编辑:我不打算解决一个truthTable 或Kmap。我已经有了结果。我的结果采用“v”向量的格式。我想使用布尔语句在 V 和 A 之间创建链接。

任何建议表示赞赏。

4

1 回答 1

2

我想问题是我的英语说得不好,但我不清楚你到底想要什么。

如果您想要一个函数,它给出一个向量std::string和一个向量bool返回bool值,根据您的指示,这很容易做到(希望不会出错)。

你使用std::begin()所以我想 C++11 对你有好处

#include <vector>
#include <iostream>
#include <stdexcept>

bool singleStatement (const std::vector<bool>  & a,
                      const std::string        & s)
 {
   auto  ret = true;

   if ( a.size() < s.size() )
      throw std::runtime_error("invalid size");

   for ( unsigned  i = 0U ; i < s.size() ; ++i )
      switch ( s[i] )
       {
         case '-': break;
         case '1': ret &= a[i]; break;
         case '0': ret &= !a[i]; break;
         default:  throw std::runtime_error("invalid char"); break;
       }

   return ret;
 }

bool statements (const std::vector<bool>        & a,
                 const std::vector<std::string> & v)
 {
   auto  ret = false;

   for ( const auto & s : v )
      ret |= singleStatement(a, s);

   return ret;
 }


int main ()
 {
   std::vector<bool>         a { true, false, false, true, false };
   std::vector<std::string>  v { "--1-0"  , "-1-1-" ,  "01-1-" }; 

   std::cout << "statement is " << statements(a, v) << std::endl;

   return EXIT_SUCCESS;
 }
于 2016-05-18T13:56:11.400 回答