zoukankan      html  css  js  c++  java
  • UVa-1103 Ancient Messages

      1 #include <bits/stdc++.h>
      2 
      3 using namespace std;
      4 
      5 const int maxn = 200;
      6 char g[maxn+3][maxn+3];
      7 int idx[maxn][maxn];
      8 int m,n;
      9 string result;
     10 
     11 string hex2bin(char c)
     12 {
     13     int index;
     14     if(c<='9')
     15         index = c-'0';
     16     else if(c=='a')
     17         index = 10;
     18     else if(c=='b')
     19         index = 11;
     20     else if(c=='c')
     21         index = 12;
     22     else if(c=='d')
     23         index = 13;
     24     else if(c=='e')
     25         index = 14;
     26     else
     27         index = 15;
     28 
     29     vector<string> List
     30     {
     31         "0000","0001","0010","0011",
     32         "0100","0101","0110","0111",
     33         "1000","1001","1010","1011",
     34         "1100","1101","1110","1111"
     35     };
     36     return List[index];
     37 }
     38 
     39 void makeGraph(char c,int x,int y)
     40 {
     41     string contain = hex2bin(c);
     42     y *= 4;
     43     for(int i = 0; i< 4; i ++)
     44     {
     45         g[x][y+i] = contain[i];
     46     }
     47 }
     48 
     49 void dfs3(int r,int c)
     50 {
     51     if(r<0 || r>=m || c<0 || c>= 4*n) return ;//出界
     52     if(idx[r][c]>0 || g[r][c]!='0')    return ;
     53     g[r][c] = -1;
     54     idx[r][c] = 1;
     55 
     56     for(int dr = -1; dr <= 1; dr ++)
     57         for(int dc = -1; dc <= 1; dc ++)
     58             if(dr != 0 || dc != 0)
     59                 dfs3(r+dr,c+dc);
     60 }
     61 
     62 void dfs1()
     63 {
     64     for(int i = 1; i <= m-2; i ++)
     65     {
     66         dfs3(i,0);
     67         dfs3(i,4*n-1);
     68     }
     69     for(int i = 0; i <= 4*n-1; i ++)
     70     {
     71         dfs3(0,i);
     72         dfs3(m-1,i);
     73     }
     74 }
     75 
     76 void dfs2(int r,int c,int &cnt)
     77 {
     78     if(r<0 || r>=m || c<0 || c>= 4*n) return ;//出界
     79     if(idx[r][c]>0 || g[r][c]!='1')    return ;
     80     g[r][c] = -1;
     81     idx[r][c] = 1;
     82 
     83     for(int dr = -1; dr <= 1; dr ++)
     84         for(int dc = -1; dc <= 1; dc ++)
     85             if(dr != 0 || dc != 0)
     86             {
     87                 if(g[r+dr][c+dc]=='0')
     88                 {
     89                     cnt ++;
     90                     dfs3(r+dr,c+dc);
     91                 }
     92                 dfs2(r+dr,c+dc,cnt);
     93             }
     94 }
     95 
     96 int kase = 0;
     97 
     98 int main()
     99 {
    100     while(cin >> m >> n)
    101     {
    102         if(m==0&&n==0)
    103             break;
    104         char tmpInput;
    105         memset(idx,0,sizeof(idx));
    106         result.clear();
    107 
    108         for(int i = 0; i < m; i ++)
    109         {
    110             for(int j = 0; j < n; j ++)
    111             {
    112                 cin >> tmpInput;
    113                 makeGraph(tmpInput,i,j);
    114             }
    115         }
    116 
    117         dfs1();
    118 
    119         for(int i = 0; i < m; i ++)
    120         {
    121             for(int j = 0; j < 4*n; j ++)
    122             {
    123                 if(g[i][j]=='1')
    124                 {
    125                     int cnt = 0;
    126                     dfs2(i,j,cnt);
    127                     if(cnt == 0)    result += 'W';
    128                     else if(cnt==1) result += 'A';
    129                     else if(cnt==2)    result += 'K';
    130                     else if(cnt==3)    result += 'J';
    131                     else if(cnt==4)    result += 'S';
    132                     else if(cnt==5)    result += 'D';
    133                 }
    134             }
    135         }
    136         sort(result.begin(),result.end());
    137         cout << "Case " << (++kase) << ": ";
    138         cout << result << endl;
    139     }
    140     return 0;
    141 }
  • 相关阅读:
    8.13实习报告
    8.10实习报告
    8.9实习报告
    8.8实习报告
    8.7实习报告
    关于线索二叉树建立和遍历
    main函数的位置可以任意
    返回指针值的函数和函数指针的区别
    runtime error: store to address 0x625000002048 with insufficient space for an object of type 'double' (solution.c) 0x625000002048: note: pointer points here
    m=-n++
  • 原文地址:https://www.cnblogs.com/Asurudo/p/9979209.html
Copyright © 2011-2022 走看看