黑白传染

#include <iostream>
using namespace std;

struct chess{
    int x;
};
int color[1000]={0};
int maxnum;

int data[1000][1000]={0};
chess p[1000];
int flag;
void bfs(int n);
int main()
{
    freopen("input.txt","r",stdin);
    int n;
    int pair;
    int x,y;
    while(scanf("%d",&n)!=EOF)
    {
        cin >>pair;
        maxnum=0;
        for(int i=1;i<=n;i++)
            color[i]=0;
        for(int i=1;i<=n;i++)
            for(int j=0;j<n;j++)
                data[i][j]=0;
        for(int i=0;i<pair;i++)
        {
            cin >>x;
            cin >>y;
            data[x][y]=1;
            data[y][x]=1;
        }

        bfs(n);
        if(flag==1)
            maxnum=-1;
        else
        {
            for(int i=1;i<=n;i++)
            {
                if(color[i]==1)
                {
                    maxnum++;
                    cout <<i<<" ";
                }
            }
            cout <<endl;
        }
        cout <<maxnum<<endl;
    }
    return 0;
}

void bfs(int n)
{
    int front=0;
    int rear=0;
    p[rear++].x=1;
    color[p[front].x]=1;
    while(rear>front)
    {
        flag=0;
        int nx=p[front].x;

        for(int i=1;i<=n;i++)
        {
            if(data[nx][i]==1)
            {
                if(color[i]==0)
                {
                    color[i]-=color[nx];
                    p[rear++].x=i;
                }
                else if(color[nx]==color[i])
                {
                    flag=1;
                    break;
                }
            }
        }
        if(flag==1)
            break;
        front++;
    }
}
时间: 2025-01-02 15:02:02

黑白传染的相关文章

CodeM美团点评编程大赛初赛B轮 黑白树【DFS深搜+暴力】

[编程题] 黑白树 时间限制:1秒 空间限制:32768K 一棵n个点的有根树,1号点为根,相邻的两个节点之间的距离为1.树上每个节点i对应一个值k[i].每个点都有一个颜色,初始的时候所有点都是白色的. 你需要通过一系列操作使得最终每个点变成黑色.每次操作需要选择一个节点i,i必须是白色的,然后i到根的链上(包括节点i与根)所有与节点i距离小于k[i]的点都会变黑,已经是黑的点保持为黑.问最少使用几次操作能把整棵树变黑. 输入描述: 第一行一个整数n (1 ≤ n ≤ 10^5) 接下来n-1

站点变为黑白

项目接近尾声了,前几天在測试的时候发现,在某个win7电脑的IE上.站点居然变成了黑白的.我的电脑是win8的系统,用IE測,更改各种文档模式均正常.令人费解. 找不到原因.更改浏览器的各种设置,均没有效果. 上网搜资料的时候发现,非常多站点为了纪念大地震或者其它日子的时候会有益把站点站点变成黑白的.没有平白无故变成的黑白的. 此时应该想到.看看怎么设置黑白.看看我的是不是也设置了.但我却认为,都是关于纪念日变黑白的,没有和我们项目类似的错误.又鼓捣了半天. 让我想到了去很考察鞋子市场的故事.思

【BZOJ】3319: 黑白树

http://www.lydsy.com/JudgeOnline/problem.php?id=3319 题意:给一棵n节点的树(n<=1e6),m个操作(m<=1e6),每次操作有两种:1.查询u到根的第一条黑边的编号.2.将u到v的路径全部染成黑色 #include <cstdio> #include <cstring> #include <cmath> #include <string> #include <iostream>

编程之美---桶中取黑白球

题目:有一个桶,里面有白球.黑球各100个,人们必须按照以下的规则把球取出来: 1.每次从桶里面拿出来两个球: 2.如果是两个同色的球,就再放入一个黑球: 3.如果是两个异色的球,就再放入一个白球: 问:最后桶里面只剩下一个黑球的概率是多少? 解法一:用黑白球各两个,来模拟,从小到多,化繁为简,进行分析和推断,找出其内在的规律,并归纳总结.推断出:每次减少一个球,每次拿球后,白球数要么不变,要么两个两个的减少.所以最后必然只剩一个黑球. 解法二:把黑球编号0,白球编号1,然后就相当于是异或操作了

Unity3d 屏幕特效实现类似死亡之后的全屏黑白效果

全屏特效 黑白(对于<着色器和屏幕特效开发秘籍>的学习) 可实现死亡效果或需要黑白特效的效果 原理是通过OnRenderImage()函数在摄像机渲染的时候,改变颜色(饱和度) 新建一个c#脚本,将要放在摄像机中 [ExecuteInEditMode] 就是让这个脚本不开始也直接运行,方便观察效果 using UnityEngine; using System.Collections; [ExecuteInEditMode] public class ShaderTest : MonoBeha

matlab练习程序(生成黑白网格)

提供了两种生成方法,一个是自己编程实现,比较灵活:另一个是调用系统的checkerboard函数,似乎只能生成8*8网格. 至于用途,也许可以用来下国际象棋. 自己函数生成: 系统函数生成: 代码如下: clear all;close all;clc h=256; w=256; n=8; img=zeros(h,w); flag=1; for y=1:h for x=1:w if flag>0 img(y,x)=255; end if mod(x,int8(w/n))==0 flag=-flag

黑白线循迹小车利用STM32F407与三个红外对管实现

小车循迹模块编程思路 所用模块:LM399红外对管循迹模块 特征:可同时搭载4个红外对管,进行黑白线检测 检测:当它探寻到黑线时候,DX口输出TTL电平接近于VCC电压 当它探寻到白线时候,DX口输出TTL电平近似为0.1V 实现功能: 让小车始终沿着黑线跑动,可以沿着黑线转弯(弯度测试),在黑线上可以设置断点,长度自己设定,路过间断线时,依然可以自主循迹到有黑线位置,并继续跑动.   初步想法: 无论是两个轮子的解构还是四轮结构,利用后面两个轮子作为主动轮,前面两个轮子作为从动轮.所以就得实现

TCL牵手美的,黑白跨界齐聚520

5月20日,不仅是年轻人的一个特殊日子,因为其谐音"我爱你",很多人会借助这一天,向身边的爱人.家人或朋友表达爱意.这么重要的一个日子,家电行业也不会放弃开展一场的促销活动,据TCL官方得知,TCL电视将联合美的空调举办"520家电黑白配"为爱放价大行动,此次TCL与美的的跨界牵手,将一次性为消费者解决电视与空调的两大购物需求,让这个夏天吹着空调看球赛. 线上线下钜惠520家电黑白配 作为全球电视品牌前三的TCL和长期高居一二级能效产品市场榜首的美的空调,两大品牌互

Android自动化压力测试之Monkey Test Android常见的错误类型及黑白名单的使用方法(四)

Android常见的错误类型有两种 1.ANR类型 1)在5秒内没有响应输入的事件(例如,按键按下,屏幕触摸) 2)BroadcastReceiver在10秒内没有执行完毕 2.Crash类型 1)异常停止 2)异常退出 Monkey 调试参数 --kill-process-after-error  犹豫一个错误而停止时,出错的应用程序将继续处于运行状态 --wait-dbg   启动monkey后,先中断其运行,等待调试器附加上来 命令演示 adb shell monkey -p com.da