图论/暴力 Codeforces Beta Round #94 (Div. 2 Only) B. Students and Shoelaces

题目传送门

 1 /*
 2     图论/暴力:这是个连通的问题,每一次把所有度数为1的砍掉,把连接的点再砍掉,总之很神奇,不懂:)
 3 */
 4 #include <cstdio>
 5 #include <cstring>
 6 #include <algorithm>
 7 #include <cmath>
 8 using namespace std;
 9
10 const int MAXN = 1e2 + 10;
11 const int INF = 0x3f3f3f3f;
12 int cnt[MAXN];
13 int a[MAXN];
14 bool g[MAXN][MAXN];
15
16 int main(void)        //Codeforces Beta Round #94 (Div. 2 Only) B. Students and Shoelaces
17 {
18 //    freopen ("B.in", "r", stdin);
19     int n, m;
20     while (scanf ("%d%d", &n, &m) == 2)
21     {
22         memset (cnt, 0, sizeof (cnt));
23         memset (g, false, sizeof (g));
24         for (int i=1; i<=m; ++i)
25         {
26             int x, y;    scanf ("%d%d", &x, &y);
27             cnt[x]++;    cnt[y]++;
28             g[x][y] = g[y][x] = true;
29         }
30
31         int t = 0;    int ans = -1;
32         do{
33             t = 0;
34             for (int i=1; i<=n; ++i)
35             {
36                 if (cnt[i] == 1)    {cnt[i]--;    a[++t] = i;}
37             }
38             for (int i=1; i<=t; ++i)
39             {
40                 for (int j=1; j<=n; ++j)
41                 {
42                     if (g[a[i]][j] == true)    cnt[j]--;
43                 }
44             }
45             ++ans;
46         }while (t > 0);
47
48         printf ("%d\n", ans);
49     }
50
51     return 0;
52 }
53
54
55 /*
56 3 3
57 1 2
58 2 3
59 3 1
60 6 3
61 1 2
62 2 3
63 3 4
64 6 5
65 1 4
66 2 4
67 3 4
68 5 4
69 6 4
70 */
时间: 2024-10-13 21:27:38

图论/暴力 Codeforces Beta Round #94 (Div. 2 Only) B. Students and Shoelaces的相关文章

BFS Codeforces Beta Round #94 (Div. 2 Only) C. Statues

题目传送门 1 /* 2 BFS:三维BFS,坐标再加上步数,能走一个点当这个地方在步数内不能落到.因为雕像最多8步就会全部下落, 3 只要撑过这个时间就能win,否则lose 4 */ 5 #include <cstdio> 6 #include <algorithm> 7 #include <queue> 8 #include <vector> 9 #include <cstring> 10 using namespace std; 11 1

暴力/DP Codeforces Beta Round #22 (Div. 2 Only) B. Bargaining Table

题目传送门 1 /* 2 题意:求最大矩形(全0)的面积 3 暴力/dp:每对一个0查看它左下的最大矩形面积,更新ans 4 注意:是字符串,没用空格,好事多磨,WA了多少次才发现:( 5 详细解释:http://www.cnblogs.com/cszlg/p/3217478.html 6 */ 7 #include <cstdio> 8 #include <algorithm> 9 #include <cstring> 10 #include <cmath>

Codeforces Beta Round #91 (Div. 1 Only) E. Lucky Array

E. Lucky Array Petya loves lucky numbers. Everybody knows that lucky numbers are positive integers whose decimal representation contains only the lucky digits 4 and 7. For example, numbers 47, 744, 4 are lucky and 5, 17, 467are not. Petya has an arra

Codeforces Beta Round #12 (Div 2 Only)

Codeforces Beta Round #12 (Div 2 Only) http://codeforces.com/contest/12 A 水题 1 #include<bits/stdc++.h> 2 using namespace std; 3 #define lson l,mid,rt<<1 4 #define rson mid+1,r,rt<<1|1 5 #define sqr(x) ((x)*(x)) 6 #define maxn 1000010 7 t

Codeforces Beta Round #31 (Div. 2, Codeforces format)

Codeforces Beta Round #31 (Div. 2, Codeforces format) http://codeforces.com/contest/31 A 1 #include<bits/stdc++.h> 2 using namespace std; 3 #define lson l,mid,rt<<1 4 #define rson mid+1,r,rt<<1|1 5 #define sqr(x) ((x)*(x)) 6 #define pb p

Codeforces Beta Round #49 (Div. 2)

Codeforces Beta Round #49 (Div. 2) http://codeforces.com/contest/53 A 1 #include<bits/stdc++.h> 2 using namespace std; 3 #define lson l,mid,rt<<1 4 #define rson mid+1,r,rt<<1|1 5 #define sqr(x) ((x)*(x)) 6 #define pb push_back 7 #define

Codeforces Beta Round #59 (Div. 2)

Codeforces Beta Round #59 (Div. 2) http://codeforces.com/contest/63 A 1 #include<bits/stdc++.h> 2 using namespace std; 3 #define lson l,mid,rt<<1 4 #define rson mid+1,r,rt<<1|1 5 #define sqr(x) ((x)*(x)) 6 #define pb push_back 7 #define

Codeforces Beta Round #85 (Div. 1 Only) C (状态压缩或是数学?)

C. Petya and Spiders Little Petya loves training spiders. Petya has a board n × m in size. Each cell of the board initially has a spider sitting on it. After one second Petya chooses a certain action for each spider, and all of them humbly perform it

Codeforces Beta Round #6 (Div. 2 Only) B. President&#39;s Office

题目大意 给出一个n*m的矩阵 ,描述桌子的布局.总统的桌子和他的副手的桌子相邻,每一个人的桌子有它独有的颜色.问总统有多少个副手. 解题思路 搜出总统的桌子在矩阵中的边界后判断边界外的其它颜色桌子的数量. 题目代码 #include <set> #include <map> #include <queue> #include <math.h> #include <vector> #include <string> #include