蓝桥杯(七段码,C++)

思路:

1、把灯管的连接转为图结构,相邻的灯管即认为有边。

2、用深度搜索,去计算有多少种不同字符。

3、因为有每种字符都会重复算两遍,最后的结果需要数以2。

cpp 复制代码
#include <iostream>
using namespace std;
 int graph[7][7] = {//转化成图
      {1,1,0,0,0,1,0},
      {1,1,1,0,0,0,1},
      {0,1,1,1,0,0,1},
      {0,0,1,1,1,0,0},
      {0,0,0,1,1,1,1},
      {1,0,0,0,1,1,1},
      {0,1,1,0,1,1,1}
    };
int book[7] = { 0 };//记录灯管是否被点亮
int dfs(int n, int i) //本灯管亮后可能构成几种字符=下一根灯管亮+其连通分支的数量
{
    int sum = 1;
    for (int k = 0; k < n; k++)
    {
        if (graph[i][k] == 1 && book[k] == 0)
        {
            book[k] = 1;
            sum+=dfs(7, k);
            book[k] = 0;
        }
    }
    return sum;
}
int main()
{
    cout << dfs(7, 0) / 2;
    return 0;
}
相关推荐
张健11564096487 小时前
使用信号量限制并发数量
开发语言·c++
jc06207 小时前
6.1云原生之Docker
c++·docker·云原生
叶子野格10 小时前
《C语言学习:指针》12
c语言·开发语言·c++·学习·visual studio
Fuyo_111910 小时前
C++ 内存管理
c++·笔记
澈20711 小时前
C++面向对象:类与对象核心解析
c++·算法
6Hzlia11 小时前
【Hot 100 刷题计划】 LeetCode 141. 环形链表 | C++ 哈希表直觉解法
c++·leetcode·链表
handler0112 小时前
Linux 进程探索:从 PCB 管理到 fork() 的写时拷贝
linux·c语言·c++·笔记·学习
众少成多积小致巨13 小时前
GNU Make 核心指南
android·c++
谭欣辰13 小时前
详细讲解 C++ 状压 DP
开发语言·c++·动态规划
William_wL_13 小时前
【C++】stack和queue的使用和实现(附加deque的简单介绍)
开发语言·c++