zoukankan      html  css  js  c++  java
  • Frogs' Neighborhood(POJ1659+Havel-Hakimi定理)

    题目链接:http://poj.org/problem?id=1659

    题目:

    题意:根据他给你的每个点的度数构造一张无向图。

    思路:自己WA了几发(好菜啊……)后看到discuss才知道这个要用Havel-Hakimi定理,就跑去搜,这个定理很好理解,想了解的看官请点击链接:http://blog.51cto.com/sbp810050504/883904。

    代码实现如下:

     1 #include <set>
     2 #include <map>
     3 #include <queue>
     4 #include <stack>
     5 #include <cmath>
     6 #include <bitset>
     7 #include <cstdio>
     8 #include <string>
     9 #include <vector>
    10 #include <cstdlib>
    11 #include <cstring>
    12 #include <iostream>
    13 #include <algorithm>
    14 using namespace std;
    15 
    16 typedef long long ll;
    17 typedef pair<ll, ll> pll;
    18 typedef pair<ll, int> pli;
    19 typedef pair<int, ll> pil;;
    20 typedef pair<int, int> pii;
    21 typedef unsigned long long ull;
    22 
    23 #define lson i<<1
    24 #define rson i<<1|1
    25 #define bug printf("*********
    ");
    26 #define FIN freopen("D://code//in.txt", "r", stdin);
    27 #define debug(x) cout<<"["<<x<<"]" <<endl;
    28 #define IO ios::sync_with_stdio(false),cin.tie(0);
    29 
    30 const double eps = 1e-8;
    31 const int mod = 10007;
    32 const int maxn = 1e6 + 7;
    33 const double pi = acos(-1);
    34 const int inf = 0x3f3f3f3f;
    35 const ll INF = 0x3f3f3f3f3f3f3f;
    36 
    37 int t, n;
    38 int mp[15][15];
    39 
    40 struct node {
    41     int id, w;
    42     bool operator < (const node& x) const {
    43         return w > x.w;
    44     }
    45 }a[15];
    46 
    47 int main() {
    48     //FIN;
    49     scanf("%d", &t);
    50     for(int icase = 1; icase <= t; icase++) {
    51         if(icase != 1) printf("
    ");
    52         memset(mp, 0, sizeof(mp));
    53         scanf("%d", &n);
    54         for(int i = 1; i <= n; i++) {
    55             scanf("%d", &a[i].w);
    56             a[i].id = i;
    57         }
    58         int flag = 1;
    59         for(int i = 1; i <= n; i++) {
    60             sort(a + 1, a + n + 1);
    61             for(int j = 1; j <= a[1].w; j++) {
    62                 a[j+1].w--;
    63                 mp[a[1].id][a[j+1].id] = mp[a[j+1].id][a[1].id] = 1;
    64             }
    65             a[1].w = 0;
    66             for(int j = 1; j <= n; j++) {
    67                 if(a[j].w < 0) {
    68                     flag = 0;
    69                     break;
    70                 }
    71             }
    72             if(!flag) break;
    73         }
    74         if(!flag) puts("NO");
    75         else {
    76             puts("YES");
    77             for(int i = 1; i <= n; i++) {
    78                 for(int j = 1; j <= n; j++) {
    79                     printf("%d%c", mp[i][j], j == n ? '
    ' : ' ');
    80                 }
    81             }
    82         }
    83     }
    84     return 0;
    85 }
  • 相关阅读:
    软件工程课程作业(四)--返回一个整数数组中最大子数组的和
    构建之法阅读笔记02
    第三周学习进度
    Delphi 之 编辑框控件(TEdit)
    Delphi 之 标签组件(TLabel组件)
    Delphi 之 第九课 Windows编程
    Delphi 之 第八课 动态数组
    VB API 之 第六课 字体应用三
    VB API 之 第五课 字体之其他函数介绍
    Delphi 之 第七课 字符串操作
  • 原文地址:https://www.cnblogs.com/Dillonh/p/9409993.html
Copyright © 2011-2022 走看看