RError.com

RError.com Logo RError.com Logo

RError.com Navigation

  • 主页

Mobile menu

Close
  • 主页
  • 系统&网络
    • 热门问题
    • 最新问题
    • 标签
  • Ubuntu
    • 热门问题
    • 最新问题
    • 标签
  • 帮助
主页 / 问题 / 1295382
Accepted
Learpcs
Learpcs
Asked:2022-06-15 16:33:47 +0000 UTC2022-06-15 16:33:47 +0000 UTC 2022-06-15 16:33:47 +0000 UTC

C++ 错误地解决了布尔代数问题

  • 772

任务:

任务

决定做一个蛮力:

#include <iostream>
using namespace std;

bool func(bool x, bool y, bool z, bool w)
{
    return (!y + z + !x * w) == (w == z);
}

int main()
{
    cout << "x" << " " << "y" << " " << "z" << " " << "w" << " " << "F" << endl;
    for (size_t x = 0; x < 2; x++)
    {
        for (size_t y = 0; y < 2; y++)
        {
            for (size_t z = 0; z < 2; z++)
            {
                for (size_t w = 0; w < 2; w++)
                {
                    if (func(x, y, z, w) == 1)
                    {
                        cout << x << " " << y << " " << z << " " << w << " " << "1" << endl;
                    }
                }
            }
        }
    }

}

程序输出:

x y z w F
0 0 0 0 1
1 0 0 0 1
1 1 0 1 1
1 1 1 1 1

我将稍微更改程序代码,使输出列与条件列相同。

#include <iostream>
using namespace std;

bool func(bool x, bool y, bool z, bool w)
{
    return (!y + z + !x * w) == (w == z);
}

int main()
{
    cout << "w" << " " << "y" << " " << "z" << " " << "x" << " " << "F" << endl; //<=== поменял местами x и w
    for (size_t x = 0; x < 2; x++)
    {
        for (size_t y = 0; y < 2; y++)
        {
            for (size_t z = 0; z < 2; z++)
            {
                for (size_t w = 0; w < 2; w++)
                {
                    if (func(x, y, z, w) == 1)
                    {
                        cout << w << " " << y << " " << z << " " << x << " " << "1" << endl; //<=== поменял местами x и w
                    }
                }
            }
        }
    }
}

程序输出:

w y z x F
0 0 0 0 1
0 0 0 1 1
1 1 0 1 1
1 1 1 1 1

来自条件的表格:

在此处输入图像描述

总的来说,我们看到程序输出的第二行等于条件表的第二行。但是条件表中有第一行和第三行,程序输出中只有一行(第三行)可以对应。问题是什么?我的程序没有生成所有可能的组合?

c++
  • 1 1 个回答
  • 10 Views

1 个回答

  • Voted
  1. Best Answer
    Harry
    2022-06-15T18:33:57Z2022-06-15T18:33:57Z

    第一行非常不一致:) - 1 应该来自输入 0100 和 1100。

    通过直接替换一个变量 1 和其余 0 的第一个集合给出了这个 x 必须是 1。所以,我们已经确定了第二个字母。

    现在,代入 x==1,我们得到条件 (!y || z) == (w == z)。同样,交替选择 y、z、w 等于 1,其余为 0,我们发现这样的集合不存在(自己看)。

    所以问题没有解决办法。

    我画的程序是这样的——

    #include <algorithm>
    #include <iostream>
    #include <iomanip>
    
    using namespace std;
    
    bool chk(bool a[4])
    {
        return bool(((!a[2])||a[3])||((!a[1])&&a[0])) == bool(a[0] == a[3]);
    }
    
    void F(int p[4])
    {
        bool a[][4] =
        {
            {false,true,false,false},{true,true,false,false},  // line 1
            {false,false,false,true},                          // line 2
            // line 3
            {false,true,false,false},{false,true,false,true},{false,true,true,false},{false,true,true,true}
        };
    
        bool res = true;
    
        for(int i = 0; i < sizeof(a)/sizeof(a[0]); ++i)
        {
            bool b[4];
            b[0] = a[i][p[0]];
            b[1] = a[i][p[1]];
            b[2] = a[i][p[2]];
            b[3] = a[i][p[3]];
            res = res && chk(b);
        }
    
        if (res)
        {
            cout << "wxyz"[p[0]] << "wxyz"[p[1]] << "wxyz"[p[2]] << "wxyz"[p[3]] << endl;
        }
    }
    
    int main()
    {
        int p[4] = { 0,1,2,3 };
        do
        {
            F(p);
        } while(next_permutation(p,p+4));
    
    }
    

    她说没有解决方案,好吧,然后我只是寻找矛盾的条件......

    也许我以某种错误的方式解释了任务 - 然后向我解释我错了什么,我会进一步思考......

    更新

    由 Mikhailo 纠正,是的,这个问题有一个独特的解决方案 - xzyw,新代码 -

    bool chk(bool a[4])
    {
        return bool(((!a[2])||a[3])||((!a[1])&&a[0])) == bool(a[0] == a[3]);
    }
    
    bool chk(int p[4], bool a[4])
    {
        bool b[4];
        b[0] = a[p[0]];
        b[1] = a[p[1]];
        b[2] = a[p[2]];
        b[3] = a[p[3]];
        return chk(b);
    }
    
    void F(int p[4])
    {
        bool a[][4] =
        {
            {false,true,false,false},{true,true,false,false},  // line 1
            {false,false,false,true},                          // line 2
            // line 3
            {false,true,false,false},{false,true,false,true},{false,true,true,false},{false,true,true,true}
        };
    
        bool res = (chk(p,a[0])||chk(p,a[1])) && chk(p,a[2]) &&
            (chk(p,a[3])||chk(p,a[4])||chk(p,a[5])||chk(p,a[6]));
    
        if (res)
        {
            cout << "wxyz"[p[0]] << "wxyz"[p[1]] << "wxyz"[p[2]] << "wxyz"[p[3]] << endl;
        }
    }
    
    int main()
    {
        int p[4] = { 0,1,2,3 };
        do
        {
            F(p);
        } while(next_permutation(p,p+4));
    
    }
    
    • 2

相关问题

  • 编译器和模板处理

  • 指针。找到最小数量

  • C++,关于枚举类对象初始化的问题

  • 函数中的二维数组

  • 无法使用默认构造函数创建类对象

  • C++ 和循环依赖

Sidebar

Stats

  • 问题 10021
  • Answers 30001
  • 最佳答案 8000
  • 用户 6900
  • 常问
  • 回答
  • Marko Smith

    表格填充不起作用

    • 2 个回答
  • Marko Smith

    提示 50/50,有两个,其中一个是正确的

    • 1 个回答
  • Marko Smith

    在 PyQt5 中停止进程

    • 1 个回答
  • Marko Smith

    我的脚本不工作

    • 1 个回答
  • Marko Smith

    在文本文件中写入和读取列表

    • 2 个回答
  • Marko Smith

    如何像屏幕截图中那样并排排列这些块?

    • 1 个回答
  • Marko Smith

    确定文本文件中每一行的字符数

    • 2 个回答
  • Marko Smith

    将接口对象传递给 JAVA 构造函数

    • 1 个回答
  • Marko Smith

    正确更新数据库中的数据

    • 1 个回答
  • Marko Smith

    Python解析不是css

    • 1 个回答
  • Martin Hope
    Alexandr_TT 2020年新年大赛! 2020-12-20 18:20:21 +0000 UTC
  • Martin Hope
    Alexandr_TT 圣诞树动画 2020-12-23 00:38:08 +0000 UTC
  • Martin Hope
    Air 究竟是什么标识了网站访问者? 2020-11-03 15:49:20 +0000 UTC
  • Martin Hope
    Qwertiy 号码显示 9223372036854775807 2020-07-11 18:16:49 +0000 UTC
  • Martin Hope
    user216109 如何为黑客设下陷阱,或充分击退攻击? 2020-05-10 02:22:52 +0000 UTC
  • Martin Hope
    Qwertiy 并变成3个无穷大 2020-11-06 07:15:57 +0000 UTC
  • Martin Hope
    koks_rs 什么是样板代码? 2020-10-27 15:43:19 +0000 UTC
  • Martin Hope
    Sirop4ik 向 git 提交发布的正确方法是什么? 2020-10-05 00:02:00 +0000 UTC
  • Martin Hope
    faoxis 为什么在这么多示例中函数都称为 foo? 2020-08-15 04:42:49 +0000 UTC
  • Martin Hope
    Pavel Mayorov 如何从事件或回调函数中返回值?或者至少等他们完成。 2020-08-11 16:49:28 +0000 UTC

热门标签

javascript python java php c# c++ html android jquery mysql

Explore

  • 主页
  • 问题
    • 热门问题
    • 最新问题
  • 标签
  • 帮助

Footer

RError.com

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

帮助

© 2023 RError.com All Rights Reserve   沪ICP备12040472号-5