P1330 封锁阳光大学(搜索+图的遍历和存储)

给你一幅图,问你最少占领几个点,能够封锁阳光大学,但是不能占领一条边的两个点

就是每条边有且只有一个点能被占领,这么一来,每个连通分量只可能有两个方案(占领变不占领),所以直接搜,加上少的就好了

 1 #include<iostream>
 2 using namespace std;
 3 const int N=1e5+100;
 4 int cnt=0;
 5 struct node
 6 {
 7     int to;//到的点
 8     int from;//出发点相同的边在数组中的位置
 9 }edge[N];
10 int head[N];
11 void add(int a,int b)
12 {
13     cnt++;
14     edge[cnt].to=b;//这条边到达的点
15     edge[cnt].from=head[a];//存下目前最新的和我同出发点的边所在位置(因为我就要替换他了)
16     head[a]=cnt;
17 }//链式向前星(难)
18
19 bool used[N];
20 int color[N];
21 int sum[2];
22 bool dfs(int now,int col)
23 {
24     if(used[now])
25     {
26         if(color[now]==col)//如果走完一遍回来,发现自个儿的颜色还得变,那就是impossible了
27         {
28             return true;
29         }
30         return false;
31     }
32     used[now]=true;//标记
33     color[now]=col;//记录现在在的点的颜色
34     sum[col]++;//这种颜色的点加一
35     bool flag=1;
36     for(int i=head[now];i!=0&&flag;i=edge[i].from)//遍历所有的边,可以理解为深度遍历
37     {
38         if(!dfs(edge[i].to,!col))//如果下一个点出问题了,一路返回false
39             flag=0;
40     }
41     return flag;
42 }
43 int main(void)
44 {
45     int n,m;
46     cin>>n>>m;
47     for(int i=1;i<=m;i++)
48     {
49         int a,b;
50         cin>>a>>b;
51         add(a,b);//无向图
52         add(b,a);
53     }
54     int ans=0;
55     for(int i=1;i<=n;i++)
56     {
57         if(used[i])
58             continue;
59         sum[0]=sum[1]=0;//初始化
60         if(!dfs(i,0))//如果不能完成染色,直接输出im
61         {
62             cout<<"Impossible";
63             return 0;
64         }
65         ans+=min(sum[0],sum[1]);//加上小的
66     }
67     cout<<ans;
68     return 0;
69 }

原文地址:https://www.cnblogs.com/greenofyu/p/12229916.html

时间: 2024-10-26 00:16:16

P1330 封锁阳光大学(搜索+图的遍历和存储)的相关文章

luogu P1330 封锁阳光大学--图上染色

P1330 封锁阳光大学 题目描述 曹是一只爱刷街的老曹,暑假期间,他每天都欢快地在阳光大学的校园里刷街.河蟹看到欢快的曹,感到不爽.河蟹决定封锁阳光大学,不让曹刷街. 阳光大学的校园是一张由N个点构成的无向图,N个点之间由M条道路连接.每只河蟹可以对一个点进行封锁,当某个点被封锁后,与这个点相连的道路就被封锁了,曹就无法在与这些道路上刷街了.非常悲剧的一点是,河蟹是一种不和谐的生物,当两只河蟹封锁了相邻的两个点时,他们会发生冲突. 询问:最少需要多少只河蟹,可以封锁所有道路并且不发生冲突. 输

P1330 封锁阳光大学(染色问题)

P1330 封锁阳光大学 题目描述 曹是一只爱刷街的老曹,暑假期间,他每天都欢快地在阳光大学的校园里刷街.河蟹看到欢快的曹,感到不爽.河蟹决定封锁阳光大学,不让曹刷街. 阳光大学的校园是一张由N个点构成的无向图,N个点之间由M条道路连接.每只河蟹可以对一个点进行封锁,当某个点被封锁后,与这个点相连的道路就被封锁了,曹就无法在与这些道路上刷街了.非常悲剧的一点是,河蟹是一种不和谐的生物,当两只河蟹封锁了相邻的两个点时,他们会发生冲突. 询问:最少需要多少只河蟹,可以封锁所有道路并且不发生冲突. 输

P1330 封锁阳光大学

P1330 封锁阳光大学 题目描述 曹是一只爱刷街的老曹,暑假期间,他每天都欢快地在阳光大学的校园里刷街.河蟹看到欢快的曹,感到不爽.河蟹决定封锁阳光大学,不让曹刷街. 阳光大学的校园是一张由N个点构成的无向图,N个点之间由M条道路连接.每只河蟹可以对一个点进行封锁,当某个点被封锁后,与这个点相连的道路就被封锁了,曹就无法在与这些道路上刷街了.非常悲剧的一点是,河蟹是一种不和谐的生物,当两只河蟹封锁了相邻的两个点时,他们会发生冲突. 询问:最少需要多少只河蟹,可以封锁所有道路并且不发生冲突. 输

luogu P1330 封锁阳光大学 x

P1330 封锁阳光大学 题目描述 曹是一只爱刷街的老曹,暑假期间,他每天都欢快地在阳光大学的校园里刷街.河蟹看到欢快的曹,感到不爽.河蟹决定封锁阳光大学,不让曹刷街. 阳光大学的校园是一张由N个点构成的无向图,N个点之间由M条道路连接.每只河蟹可以对一个点进行封锁,当某个点被封锁后,与这个点相连的道路就被封锁了,曹就无法在与这些道路上刷街了.非常悲剧的一点是,河蟹是一种不和谐的生物,当两只河蟹封锁了相邻的两个点时,他们会发生冲突. 询问:最少需要多少只河蟹,可以封锁所有道路并且不发生冲突. 输

洛谷p1330 封锁阳光大学

P1330 封锁阳光大学 335通过 907提交 题目提供者yeszy 标签图论福建省历届夏令营 难度普及+/提高 提交该题 讨论 题解 记录 最新讨论 为什么本地会报202? 给一个样例 题目描述 曹是一只爱刷街的老曹,暑假期间,他每天都欢快地在阳光大学的校园里刷街.河蟹看到欢快的曹,感到不爽.河蟹决定封锁阳光大学,不让曹刷街. 阳光大学的校园是一张由N个点构成的无向图,N个点之间由M条道路连接.每只河蟹可以对一个点进行封锁,当某个点被封锁后,与这个点相连的道路就被封锁了,曹就无法在与这些道路

洛谷P1330 封锁阳光大学(二分图染色)

P1330 封锁阳光大学 题目描述 曹是一只爱刷街的老曹,暑假期间,他每天都欢快地在阳光大学的校园里刷街.河蟹看到欢快的曹,感到不爽.河蟹决定封锁阳光大学,不让曹刷街. 阳光大学的校园是一张由N个点构成的无向图,N个点之间由M条道路连接.每只河蟹可以对一个点进行封锁,当某个点被封锁后,与这个点相连的道路就被封锁了,曹就无法在与这些道路上刷街了.非常悲剧的一点是,河蟹是一种不和谐的生物,当两只河蟹封锁了相邻的两个点时,他们会发生冲突. 询问:最少需要多少只河蟹,可以封锁所有道路并且不发生冲突. 输

洛谷 P1330 封锁阳光大学 Label:染色问题

题目描述 曹是一只爱刷街的老曹,暑假期间,他每天都欢快地在阳光大学的校园里刷街.河蟹看到欢快的曹,感到不爽.河蟹决定封锁阳光大学,不让曹刷街. 阳光大学的校园是一张由N个点构成的无向图,N个点之间由M条道路连接.每只河蟹可以对一个点进行封锁,当某个点被封锁后,与这个点相连的道路就被封锁了,曹就无法在与这些道路上刷街了.非常悲剧的一点是,河蟹是一种不和谐的生物,当两只河蟹封锁了相邻的两个点时,他们会发生冲突. 询问:最少需要多少只河蟹,可以封锁所有道路并且不发生冲突. 输入输出格式 输入格式: 第

洛谷 P1330 封锁阳光大学

题目描述 曹是一只爱刷街的老曹,暑假期间,他每天都欢快地在阳光大学的校园里刷街.河蟹看到欢快的曹,感到不爽.河蟹决定封锁阳光大学,不让曹刷街. 阳光大学的校园是一张由N个点构成的无向图,N个点之间由M条道路连接.每只河蟹可以对一个点进行封锁,当某个点被封锁后,与这个点相连的道路就被封锁了,曹就无法在与这些道路上刷街了.非常悲剧的一点是,河蟹是一种不和谐的生物,当两只河蟹封锁了相邻的两个点时,他们会发生冲突. 询问:最少需要多少只河蟹,可以封锁所有道路并且不发生冲突. 输入输出格式 输入格式: 第

洛谷——P1330 封锁阳光大学

https://www.luogu.org/problem/show?pid=1330#sub 题目描述 曹是一只爱刷街的老曹,暑假期间,他每天都欢快地在阳光大学的校园里刷街.河蟹看到欢快的曹,感到不爽.河蟹决定封锁阳光大学,不让曹刷街. 阳光大学的校园是一张由N个点构成的无向图,N个点之间由M条道路连接.每只河蟹可以对一个点进行封锁,当某个点被封锁后,与这个点相连的道路就被封锁了,曹就无法在与这些道路上刷街了.非常悲剧的一点是,河蟹是一种不和谐的生物,当两只河蟹封锁了相邻的两个点时,他们会发生