题目链接:

http://acm.hdu.edu.cn/showproblem.php?pid=1198

题目大意:

有如上图11种土地块,块中的绿色线条为土地块中修好的水渠,现在一片土地由上述的各种土地块组成,需要浇水,问需要打多少口井。

例如下面这个土地块

ADC

FJK
IHE

then the water pipes are distributed like

解题思路:

首先模拟A-K的四个不同的方向,用了一个数组表示从A-K的四个方向是否有水管

然后枚举每个点的四个方向上可到达的地方,如果连通就合并并查集,最后根节点的数目就是连通块的数目(DFS也可以做,判断连通块即可)

 #include<bits/stdc++.h>
using namespace std;
typedef long long ll;
const int maxn = + ;
int p[maxn];
char Map[][];
int dir[][] = {,-,-,,,,,};//分别是左(0),上(1),右(2),下(3)
int G[][]={
,,,,
,,,,
,,,,
,,,,
,,,,
,,,,
,,,,
,,,,
,,,,
,,,,
,,,,
};
void init()
{
for(int i = ; i < maxn; i++)p[i] = i;
}
int Find(int x)
{
return x == p[x] ? x : p[x] = Find(p[x]);
}
void Union(int x, int y)
{
x = Find(x);
y = Find(y);
if(x != y)
{
p[x] = y;
}
}
int main()
{
int n, m;
freopen("out.txt", "w", stdout);
while(cin >> n >> m && ( n + m > ))
{
init();
for(int i = ; i < n; i++)
{
cin >> Map[i];
}
for(int i = ; i < n; i++)
{
for(int j = ; j < m; j++)
{
int c = Map[i][j] - 'A';
for(int k = ; k < ; k++)//枚举四个方向
{
if(!G[c][k])continue;//判断该方向是否存在水管
int x = i + dir[k][];
int y = j + dir[k][];
if(x < || x >= n || y < || y >= m)continue;
int d = Map[x][y] - 'A';
if(!G[d][(k + ) % ])continue;//这里是判断(x,y)处是否有和k方向相对的方向的水管
Union(i * m + j, x * m + y);//这里是编号i*m+j,一开始写错成i*n+j
}
}
}
int flag = ;
for(int i = ; i < n * m; i++)
{
if(p[i] == i)flag++;//根节点的数目也就是连通块的数目
}
cout<<flag<<endl;
}
return ;
}

测试数据:

 JBHFFKBAHHFIGHDHJ
CHHIKGHIFGHCBJKKC
EJHFEHFGHAFAFEFBD
KGAAGHIHKDFCKJKDK
BBGIFFCEGGFGFABEF
GFHEAIEEADDFIEHIC
AIHHEBFCHJAKDIEBG
CJCDGFJFHEGBKHJKH
AHCAAKHKBBKJJJGGB
HJJHFIBDAKEHEFHGD
CJJICAAJJEJIHJDEK
FKKIKJBKGKKJEEFIC
IIGJJIDFHKFDCKJDK
KBKFHKHDCJIDJBFDF
KBHBFJEIFFKFGCAIG
CKJEBHICKEGABEIHC
EJECEHIDDKJAIDEAG
KGIJAAJDHABDEIGCF
FIFJECCEKDAAKCACG
HIAFBCCDFIIKCAJBB
AAKGGBBDHAHJIIIEB
FCBIFKACGFEHIECII
IFBEKFGKFGADIHICH
HIJHFFEIHDGKEAKIE
GHCHDKBIECFJEFKHA
KHCHCDAGJDJEAKJJD
DKIKAJCCACJBCEDKD
IGHKIGDHBBFGJGKJK
DFGDIAJJHIIGCIFCC
AIGJJKKJJDJEEJFAE
CIEFBGGCBDFAFFEBK
EEAIDJEEEBDGKCFBG
DFJFACCJIGJHBDAGK
CEJFDBHCGDGHADAKB
IAJBKKHDEEAIJICBA
CBKFKEBJFJGJBDECH
EIFHJCBCBJKKIDDJA
GIABAIIDHEBIHGIDF
FFHFCFJAIFFEIJEJG
KAFFDFEIECBEFKCEK
ICKGEAFCJFIEHBHCG GKDKJKAGKAICDIJBGACJ
AHCBFGDCEDKGEAFKIBAA
JHCBAJFFEIFFFCKEHJJB
IEHDIDJCHGIBKGFDJGJC
IAGEBDGCJBKAIHGCBAHE
EGHFJIKEHCEFFFGJBBEF
DKDFABABFFADDKJEJJGB
CEIKJHCDKGIAFACFJDKG
JAGAAIIDCKKFCCJBCCAF AFEGEAGEKAHBCJDII
KAGCGJBEDJGIADCGA
CFGECKBGJHIBIBGKD
ICAFDEBHDBDFEDGGK
HDIJCJFCHJHFEGHIE
DBKJFFHBGFGGAEHED
JGGECHJGCJHAGHGDK
EKHBEHDGADFKJKECD
DFKFIIFJFKJKDBDHI
HAFKCCDFDIKCJBBGA
GFHFFFEKHCKABAJEE
HKECDKCACJKACHGAK
DHJEKABBKGIGFCJAC
JIFHJJBGDAFFGAJII
CCHCADJFHECGCBIDE
KKEKJBABDABJDBACH
CCEKGGIFFCFJEAKJB
ADIKJAFEBKCJIHFFE
KKGCBJCJDIDBGFDCF
JFBFAAJFHBABCDHAF
AIHFBJDIFGKIAGIIG
GABJIFFFKEFIABBGH
BFKEAEEHJJJEFBJFA
FJHIHDCDHIJEBHJIF IECKGJFBJFBDFBBECKEKGGGEKAA
FCHKJFDEAHGFIHHGIJJGCBEEEHG
GIEADGFJBIDIEKBDIGAJAFFGFEA
GCDIBKEJGFIJHKHABAJAHBDDBIK
FBCFCEGEDIBJIJDIKAGEBCHBCIH
KAEIKCBCEGGGHBIICFBAEIJFDEC
FDGEFKIHHGEHIDDKDBEEFCBFGKI
HDFAJBDDGHFFAHBJAHKAJCEECBF
BDDGFCFKCCIACKGEDBFJBDFDDFA
ABECCDFDAKDACBBBJBEGEABFIIK
BHHKHAGDKGDFDKGEEFEFICEGBHE
HFFKFCEFCDDFADAAAFFBCJIKKJJ
IEJGAHEBKIKBIFHBFBECJEHJHEC
JDHHHDECGCIJDFCDFGHCDJECCKG
DFEEGCJKHHCCCFEKKEIEEJIAKEA
BDIGGFKCHDKJAHCCIGBFIKAAIEC
KBECAFKFJBICDIEKEBIAGDCKFAH
FCJJEHCJCKFHIHFEFKCEJGDDIEH
BACDHJDAAIDABGFDKGEEBKKEKKJ
JHFHCGCBDBFIIFFAHFAFJGGAIFB
DHEDBHBFCFGEKGGDEFJFAHKDBBD
EGDDJIFEHIBDAIBIEHHFKDEIDAB
BGCCKBFBCBKKIFCAIJIECHICHEB
KCFKGABEKEFJFGBKGEAEFCJFIGH
BHFCEEJKBKGDBBJEEHKBFHDBGFF
CFHEDFEDJFKJECIAKBIEJAKHABD
DFEAFCEFEBHBEAKIDFDKEJAICCD
EJGDIHDHIBBEDFHKJEIFCCDHACC
GJGAIDBJDCGKKKHBAIDAAEACEDA
JCHFFAHCKGFFBCIFKGCAJAJKBBH
GHACAHIDBBIBCAAEHJBHGJGGIHI
KECKGDJGAIDIIDBJJFDKJBIHIFA
EGJKFCJAHHIIBJHIADJBAHHCDAH
AGDKCHCCECHHCAKCACHFJHIFJEA GJAGCCED
DAKIBIAH
FAEFHFKA
KCCEDIIJ
ECAIDGJE
JJBAJDFI
HFIBJEJG
KEIGFDIC
CBGFFCKK
ICAGAFGH
HCEKFBBE
DFDDACDC
BEADDBKF
CAKBCEID
IHKJFIHD
KBIHCCHK
BKBDBCGG
EHFKJKJC
IHEAKAKH
DDHKKFBD
BHGKBCEI
EIJEICIH
HFHGGKJF
KJBJCHKC
ADBEGCDH
KIADDADJ
KJBEEBII
JFHKGBHK
CHJGKJJB
GEDECEED
BCJDIGBK
DIGDHFIE
ADIEFJGH
BAKACBDH
HBDBEJGD
BJICHIAH
ADIJEKID
HBEAHCBA
HIHCAKEK
CJHKCGBC
BKEEEKCJ AGEEBDBKHKECEFBBCDIBHDDD
IGFGGKFEFHBFHCAHIBJEEDBG
BAJHKKEFEDKCIJIBECDBDBKH
JHHDCHJDHDIGHJKFHEHIGHKA
IEHCGKGJFFBEJDCHGEDIBDFH
CDHHBAGABFBDAFCJIBJDDKCC
CIJIFHFGHCCEECBGHEBCGDCI
FBCFIIJFHBJFKGJHAKBHGJIK
DGEFKHGJJCEFFKHKGGBCKIIH
IFGJCDGCDHIHBEDCJECHJBBJ KKBFAGDHJEEGHFIDKFBBBB
BKIIBJIKJFJHJJDBDBJIHI
HCBGEDAEHHFCFJJAIDEKIG
JEDFBDGDHKDBIHEJCCFAKJ
CFJAAFIEKGKHCCAIHEBKBH
CBCEIEHBGIAKHAFHEAAHKK
ECDHIEHCBGAFIECFHCEBFG
BGBBFJJIJKKDCCKGBJJABH
AGBHCKJBDHBIBBHHIGGEGC
HJKDFKAKKHGJKKEHJCIGIB
DAFAEEFGDGKBFHJKHEIBBK
FBGBEEDDAEHHIIIHHFHBKJ
IJCEDACCJAFEGEEFHBKIEH
ADKEFBAFDDDCACIAIJCEIB
HBKGDDBBFIGHKEDGHECGJI
FDBACAADDKADFCFIHAIDKH
FBIFJBDCJGJAIBBKFBDFJH
KAEKBAJBGBAHDEFHBBHKJI
HJGJBJHBKBJHAFBACEBJDF FBDBDHKDJBEGJIJHKDJFAHCKCBEDDDICECG
DKKAGKFHKIJCAHBDFDFBDKDEIEHFDIEABCG
GGHKFIFFKGEAKEBKHDFHIADCHGABEDAHJIE
KDHJFKFEKHIAJKJIFJKBGFECGJFHCEIECBB
BAGGKCKGBBKIECEIBCCAGEFIHKICKDHFKCG
FJICKFJGDAAAGCGJEIIHFCIHDJJCBCHIFAH
CEKGCHKFJAECKCIAGAEGGAKCHBBJCIKBCDD
DBIGHDKCFJIKEIBKAKAKCEGDCHJEBCHAJIA
HKIDEIDDKCGHJAAJDBFEIJFDFEAEIIFHFEB
DAFIGJGAKECEGFGGCIGGEFCFIFAAKGDJDGA
ABIJEBEEJAHHKCKDFJFCFDGBADIJJBKGKCI
JIKIBJIHBDFDHEFCFFGHJCDDBIEDGDKGBIA
KDFBGBBHCFJEFHCGJIFBHCADKCDJIDJFGCE
ABAGDCHEAJJEDFEIFICCDKFJGKJGGIGJDJB
BEGHHIHGCEDEBBJKHHEJEKDFFHJKIEAIAAE
DGFDICAEEICGJHCJEAACFHFGKFEBBAGEAHA
IKIDCIJJIEIKBCCFFFHJCJBDADHHJHCGJAJ
AFKHJKKKAFEFFAHJKKCCGJGIKKHKIGGADCF
JGCABJGJEAGHIBHGBGDCAFGGBJFDDAAHJCA
JHBCKGIHIAJFBFEBKFGGKAAKHEDGABHEKGF
HEIEIDGJJDAIHDAGGCKCEDFEKIGHCGFBFBK
JAGKDHFDBCJKCDKBHAIHBKDJDBKDCHDKDEK
DBJAFIABDDKECJHGEAKJAJKCKDFIJAAEGKB
ABGBHGKHAJGBAGFEIJBIKJBHCJGGEADCIFB
CIJFGAGIDKADJBHDBJJGKGBKGAHBDHIHBAK
EIBCHHEAEJCFKBGFJJIAKHGAEAGBGEGCGGC
HDGKDBKBHJFIJCJFKKKIBGBIIFDBFJAIKIB
IDHGAFGDKICBEECHBKKKGDIBHDGAKBEFFCH
EBGHAJFJAEAHIEHFJHBIKJKJDJDHGAHBKCC
KDIJAAAFKAKDJJEHFIGKIHJHFCKHKGGEGDF
GKEKHFDEEFCHKFBEGIFKGFICDFDBGIDBGBE
JEDKJKHFGHDIBJBKDHDICJCFIHKDFFCHBGA
DDHKGKFKBEBACKCJHADJFHHKBHJBFHFFHGA IHBGKHAEJKCDJDDEEHGHCCABIBIKG
KGJIBGACAJCCGKJHBJGBFBBDEBDKI
ICAHBGBBEFKFEEKACBIFIFGHICHCA
DHKCBJGFEFJHAFKKEKKBGJIGCGDEB
AFFDEKFBKBDIGGKAGIHIBGGKDABBK
JFIACGCFDIJHHGIDJKCFBEEEKAEIH
GIDICCGFFDFHIFBBDJECFHKGIHGCE
CEBABFIJDCIFHFKBAIJJGGCFKBEKC
FHIEKJKICFJEIKEGKIBGEAJADIHIF
EBKBHIIFEBBAGIBHIAJKBFJDDCFEG
CADAICKIJBHHEFIKIJHDEBBAEFGJI
JGEBHCDGIJDIKFCJBIHFHCFKBCGJK
DFJKCFABBIFFECHHGCKIHHKFJHBDJ
ACGCHJDKJGJFIGKFBIGKDBDBCKCBK
GKJHCIJGFHDHJAGACHFIFIAJBFGFK
FGJEAFIGBHGFBJBIJFJAHDDGCHIBK
FIFIEGHJIKFHJACAJKKCEFIGDHJGE
FBHDFKGDJJIKHKDCIJDIBFJHCFJAK
GGBDICEDIAEBFJIIIDHBKKBHHFKEB
JACKFBIHDCIGDBEGCDJFCKBDECACF
KHFIJBHKCCFCKECAJBKHHJACKEIGD
KFEAFBEIJEJHGGDAEIDJHAAHJEDFK
IGJEIAIJJKDKDCDDADJEGDCGCFDGE
GCIFJKCKHICIJKADADEGGFDCJFCDI
CEAHIBIDAEIACICKKHBJFGJGCECJE
HBKGFGCABDABCEKJCICFJDDJBJACI
JHGDJAKCHHEADHEJAJHABDCDJHBJI
EHJKCIEKACKJDJCAABGEAFJDKAAGC
DDKKJHDDDGJIADDDGEKEEJAJDEGDD KAFKGFKCFABFGCHBGEAHBCBBDHKBBDHIJEJIIACHDCBICDAH
AHIEDHBIEGIIKBAEHJJFJDBGBIKKHBAFDADCAIEEJFGCAKEK
KCDDJCDEBGHGDCFFKIIEBEJHDDAHCIDGADGHAAIFDHACJCFH
DFJHDJCEAGGEAICHEHGDKFCIGKDKEFCFFFIJKHGGECGIKKKA
AJACFFJJFCDGDIGAGCHJGKAHGEFIECACKIBGAAIBHDHIEGAF
GJIBDFIBHAGAFIDGKFGHCJAJICDJIBJEAJDAEBKGCFIJDEGC
HBABAJCHGFKGIBGBIEJDEHJAKFFHFBBHHHAIJIEDGKKBDKIJ
KIKJDKBIGCJAAIJHDAGFBEEKEFKGDHJDABCIGGBKDEFJDCKB
FDFJADGHAFFEFKIDKJBGIEHDCDGKJBICHCIAKDGBAKGCFKDI
IHJHAKDHGEJHHGGFEIHIFBEGHAJKGAEJDCAKHJKABJKGBBKB
GHBAHCIFFJGFBCACABIDFKGHHDJDKGEEIAIKKEGFHGFEBBCD
HIBADGAAHJAIAGGKCDHIBAAEKKCAHGEDDKEHHFFJGIJAHICE
CFGCAIBCDDECDJHKCJGJDKCBHDAHIKDJKAJJDADCFEKJKAFA
GCDEFHEJAIAJDGFDDADJGEIAJCKBICDGABKEDAFFGBIIHDBE
AIFDACKBJHBEEGIJDFBCJEKFBHICGGBFJCHIBJCIJIJCHAEF
KBEFKDCIEEDEBKIIBGDHGJFHGKCHJGCJFIGIDACBIGCJHKEK
CIICHEEIBGHHFCICKGECHJFBFKHBAKEGBCKCHKHKCKFDHJDG
GIKABBAIKJJDEECKBEECEHBHECDEGDICCGAGCCHCJAADBIFK

 

答案:


                          

hdu-1198 Farm Irrigation---并查集+模拟(附测试数据)的更多相关文章

  1. 杭电OJ——1198 Farm Irrigation (并查集)

    畅通工程 Problem Description 某省调查城镇交通状况,得到现有城镇道路统计表,表中列出了每条道路直接连通的城镇.省政府"畅通工程"的目标是使全省任何两个城镇间都可 ...

  2. hdu 1198 Farm Irrigation(深搜dfs || 并查集)

    转载请注明出处:viewmode=contents">http://blog.csdn.net/u012860063?viewmode=contents 题目链接:http://acm ...

  3. HDU 1198 Farm Irrigation(并查集,自己构造连通条件或者dfs)

    Farm Irrigation Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others)T ...

  4. hdu 1198 Farm Irrigation(并查集)

    题意: Benny has a spacious farm land to irrigate. The farm land is a rectangle, and is divided into a ...

  5. HDU 1198 Farm Irrigation(并查集+位运算)

    Farm Irrigation Time Limit : 2000/1000ms (Java/Other)   Memory Limit : 65536/32768K (Java/Other) Tot ...

  6. HDU 1198 Farm Irrigation(状态压缩+DFS)

    题目网址:http://acm.hdu.edu.cn/showproblem.php?pid=1198 题目: Farm Irrigation Time Limit: 2000/1000 MS (Ja ...

  7. HDU 1198 Farm Irrigation (并检查集合 和 dfs两种实现)

    Farm Irrigation Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others) ...

  8. hdu1198 Farm Irrigation 并查集

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1198 简单并查集 分别合并竖直方向和水平方向即可 代码: #include<iostream&g ...

  9. hdu.1198.Farm Irrigation(dfs +放大建图)

    Farm Irrigation Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others) ...

  10. hdu 1198 Farm Irrigation

    令人蛋疼的并查集…… 我居然做了大量的枚举,居然过了,我越来越佩服自己了 这个题有些像一个叫做“水管工”的游戏.给你一个m*n的图,每个单位可以有11种选择,然后相邻两个图只有都和对方连接,才判断他们 ...

随机推荐

  1. 定时器详解和应用、js加载阻塞、css加载阻塞

    1.setTimeout().setInterval()详解和应用 1.1 详解: setTimeout.setInterval执行时机 1.2 存在问题: setInterval重复定时器可能存在的 ...

  2. spark 机器学习 朴素贝叶斯 实现(二)

    已知10月份10-22日网球场地,会员打球情况通过朴素贝叶斯算法,预测23,24号是否适合打网球.结果,日期,天气 温度 风速结果(0否,1是)天气(0晴天,1阴天,2下雨)温度(0热,1舒适,2冷) ...

  3. POST和 GET

    http GET 和 POST 请求的优缺点.区别以及误区     Get和Post在面试中一般都会问到,一般的区别: (1)post更安全(不会作为url的一部分,不会被缓存.保存在服务器日志.以及 ...

  4. POJ1023 The Fun Number System

    题目来源:http://poj.org/problem?id=1023 题目大意: 有一种有趣的数字系统.类似于我们熟知的二进制,区别是每一位的权重有正有负.(低位至高位编号0->k,第i位的权 ...

  5. JavaScript高级程序设计第三版-读书笔记(1-3章)

    这是我第一次用markdown,也是我第一次在网上记录我自己的学习过程. 第一章 JavaScript主要由以下三个不同的部分构成 ECMAScript   提供核心语言功能 DOM     提供访问 ...

  6. DSL与GPL

    一.DSL 与 GPL DSL(Domain-Specified Language 领域特定语言),而与 DSL 相对的就是 GPL,最常见的 DSL 包括 Regex 以及 HTML & C ...

  7. Python 起步 多版本共存配置

    上次我选择的是py2.x,如果我要再装一个py3.x呢 我们去设置环境变量,然后去命令行输入python,这里我故意把环境变量放在第一行,貌似换成3.7了 我们把2.7的放在3.7的前面呢?又换回去了 ...

  8. CollectionUtils.select 集合筛选

    import org.apache.commons.collections.CollectionUtils;import org.apache.commons.collections.Predicat ...

  9. 使用nsenter工具进入Docker容器

    查看本机装没有nsenter whereis nsenter或者whatis nsenter 未安装先安装,网上有很多这样的脚本 vi nsenter.sh #!/bin/bashcurl https ...

  10. Chapter13

    package scala /** * Created by EX-CHENZECHAO001 on 2018-04-04. */class Chapter13 { // 13 集合 // 所有的集合 ...