【蓝桥杯每日一题】与或异或——DFS

与或异或

蓝桥杯每日一题 2024-12-26 与或异或 DFS

题目描述

小蓝有一张门电路的逻辑图,如下图所示: 图中每个三角形代表着一种门电路,可能是与门、或门、异或门中的任何一种,它接受上一层中的两个圆形中的数据作为输入,产生一个输出值输出到 下一级 (如图中箭头所示)。图中圆形表示的是暂存的输出结果,取值只可能是 0 或 1,为了便于表示我们用 a r r i j arrij arrij 表示第 i ( 0 ≤ i ≤ 4 ) i(0\leq i\leq 4) i(0≤i≤4) 行第 j ( 0 ≤ j ≤ i ) j(0\leq j\leq i) j(0≤j≤i) 个圆形的值。其中 a r r 0 = ( I n 0 , I n 1 , I n 2 , I n 3 , I n 4 ) arr0=(In0,In1,In2,In3,In4) arr0=(In0,In1,In2,In3,In4) 表示的是输入数据,对于某个 a r r i j ( i ≥ 0 ) arrij(i\geq 0) arrij(i≥0),计算方式为 a r r i j = a r r i − 1 j o p a r r i − 1 j + 1 arrij=arri−1j \ op \ arri−1j+1 arrij=arri−1j op arri−1j+1,其中 o p op op 表示的是将 a r r i − 1 j arri−1j arri−1j、 a r r i − 1 j + 1 arri−1j+1 arri−1j+1 作为输入,将 a r r i j arrij arrij 作为输出的那个门电路,与门、或门、异或门分别对应于按位与 &、按位或 ( ∣ ) (|) (∣) 、按位异或(^)运算符。 现在已知输入为 I n 0 = 1 , I n 1 = 0 , I n 2 = 1 , I n 3 = 0 , I n 4 = 1 In0=1,In1=0,In2=1,In3=0,In4=1 In0=1,In1=0,In2=1,In3=0,In4=1,小蓝想要使得最终的输出 O u t Out Out 的值为 1,请问一共有多少种不同的门电路组合方式?其中上图中显示的就是一种合法的方式。

解题思路

那这道题就是通过遍历来找出所能够满足条件的方法,首先具体怎么遍历,就是先通过每一遍历运算符的操作,然而每遍历一次操作,就要判断是否要换行,是否要结束递归,更新到下一个操作之后就有要进行操作符的遍历。

Accepted
cpp 复制代码
#include <iostream>
using namespace std;
int res = 0;
int arr[6][10]  = {{1,0,1,0,1}};
void dfs(int r,int c,int k) {
    if(k == 1) {
        arr[r][c] = arr[r-1][c] | arr[r-1][c+1];
    } 
    if(k == 2) {
        arr[r][c] = arr[r-1][c] ^ arr[r-1][c+1];
    }
    if(k == 3) {
        arr[r][c] = arr[r-1][c] & arr[r-1][c+1];
    }

    // 判断结束条件
    if(r == 4 && c == 0) {
        if(arr[r][c] == 1) {
            res ++;
        }
        return ;
    }

    // 当前行结束
    if(r + c == 4) {
        r++;
        c = 0;
    } else c++;

    for(int i = 1;i <= 3;i++) {
        dfs(r,c,i);
    }
}

int main()
{
    int op[3] = {1,2,3};
    
    for(int k = 1;k <= 3;k++){
      dfs(1,0,k);
    }
    cout<<res<<endl;
    return 0;
}
相关推荐
计算机安禾1 分钟前
【算法分析与设计】第45篇:交互式证明系统与零知识证明
算法·区块链·零知识证明
自进化Agent智能体5 分钟前
Hermes架构全景图:从入口到交付的完整数据流
算法
手写码匠9 分钟前
手写 Prefix Caching:从零构建 LLM 提示词缓存引擎
人工智能·深度学习·算法·aigc
枕星而眠10 分钟前
【数据结构】树与二叉树基础知识点总结
数据结构·c++·后端·算法·运维开发
海梨花11 分钟前
腾讯面试高频算法题
java·算法·面试
珂朵莉MM12 分钟前
第七届全球校园人工智能算法精英大赛-算法巅峰赛产业命题赛第3赛季优化题--整数线性规划
人工智能·算法
小则又沐风a14 分钟前
今日算法----一篇文章学会背包问题
运维·服务器·算法
不会C语言的男孩19 分钟前
C++ Primer 第16章:模板与泛型编程
开发语言·c++
2301_7644413326 分钟前
Factorization Machine(FM模型,因子分解机)
python·算法