蓝桥圣诞树(C++)

问题描述
输入样例:

1 3

101

1 2

2 3

输出样例:

YES

思路:

这道题还是比较好想的,因为它构造的二叉树是用边连接起来的,不是像之前一样从上到下从左到右按编号构造的,所以可以用邻接表来存每个点还有边,这样可以很方便的找到每个点的相邻点,然后再判断每个点是否有两个相邻点和它颜色一样(即三个连续点同色),这样就可以判断不美观的圣诞树了。

示例代码:
cpp 复制代码
#include<iostream>
#include<cstring>
using namespace std;
const int N = 1010;
int h[N], e[N], ne[N], idx;
char color[N];
void add(int a, int b)
{
    e[idx] = b;
    ne[idx] = h[a];
    h[a] = idx++;
}
int main()
{
    int t;
    cin >> t;
    while (t--)
    {
        idx=0; //对于每个样例,都需要重置idx为0,不然上一个样例创建的邻接表就会影响下一个样例
        int n;
        cin >> n;
        memset(h, -1, sizeof(h)); //邻接表初始化

        for (int i = 1; i <= n; i++)
        {
            cin >> color[i];
        }
        for (int i = 0; i < n - 1; i++)
        {
            int a, b;
            cin >> a >> b;
            add(a, b);
            add(b, a);
        }
        //遍历每个点,如果它有两个邻点颜色和它本身都一样就不行
        int flag = 0;
        for (int i = 1; i <= n; i++) //遍历所有点
        {
            int res = 0;
            for (int j = h[i]; j != -1; j = ne[j]) //找每个点的邻点
            {
                int k = e[j]; //邻点的编号
                if (color[i] == color[k]) res++; //每次找到一个邻点颜色和当前点一样就计数加一
                if (res > 1) //有两个邻点和当前点的颜色一样,说明有三个连续点是同色,即不美观
                {
                    flag = 1;
                }
            }
            if (flag) break; //找到了一组连续三个点是同色,就可以退出了
        }
        if (flag) cout << "NO" << endl;
        else cout << "YES" << endl;
    }

    return 0;
}
注意:

每次进入新样例都要重置idx为0构造新的邻接表,不然会被上一个样例影响!!!

cpp 复制代码
while (t--)
    {
        idx=0; //对于每个样例,都需要重置idx为0,不然上一个样例创建的邻接表就会影响下一个样例
        int n;
        cin >> n;
        memset(h, -1, sizeof(h)); //邻接表初始化
    }

然后我的几个错误,输入n-1行写成了

cpp 复制代码
while(n-1)
相关推荐
燃于AC之乐1 分钟前
【C++手撕STL】Vector模拟实现:从零到一的容器设计艺术
开发语言·c++·容器·stl·vector·底层·模板编程
御承扬9 分钟前
鸿蒙原生系列之懒加载瀑布流组件
c++·harmonyos·懒加载·鸿蒙ndk ui·瀑布流布局
C++ 老炮儿的技术栈15 分钟前
CMFCEditBrowseCtrl用法一例
c语言·开发语言·c++·windows·qt·visual studio code
Three~stone15 分钟前
Matlab R2024b 保姆级安装教程(附:解决win10问题)
开发语言·算法·matlab
ytttr87318 分钟前
基于MATLAB的一维对流扩散方程数值求解
开发语言·算法·matlab
qq_225891746621 分钟前
基于Python+Django豆瓣图书数据可视化分析推荐系统 可视化 协同过滤算法 情感分析 爬虫
爬虫·python·算法·信息可视化·数据分析·django
jojo_zjx22 分钟前
GESP 25年6月2级 幂和数
c++
计算机毕业设计开发23 分钟前
django高校公寓管理系统--附源码64226
java·c++·spring boot·python·spring cloud·django·php
one____dream23 分钟前
【算法】移除链表元素与反转链表
数据结构·python·算法·链表
memmolo24 分钟前
【3D测量中的术语:系统误差、随机误差、精密度、准确度】
算法·计算机视觉·3d