`
hellojyj
  • 浏览: 62301 次
  • 性别: Icon_minigender_1
  • 来自: 长沙
社区版块
存档分类
最新评论

POJ 3620 Avoid The Lakes

    博客分类:
  • ACM
阅读更多

原题传送门:http://poj.org/problem?id=3620

 

Avoid The Lakes
Time Limit: 1000MS   Memory Limit: 65536K
Total Submissions: 6211   Accepted: 3370

Description

Farmer John's farm was flooded in the most recent storm, a fact only aggravated by the information that his cows are deathly afraid of water. His insurance agency will only repay him, however, an amount depending on the size of the largest "lake" on his farm.

The farm is represented as a rectangular grid with N (1 ≤ N ≤ 100) rows and M (1 ≤ M ≤ 100) columns. Each cell in the grid is either dry or submerged, and exactly K (1 ≤ KN × M) of the cells are submerged. As one would expect, a lake has a central cell to which other cells connect by sharing a long edge (not a corner). Any cell that shares a long edge with the central cell or shares a long edge with any connected cell becomes a connected cell and is part of the lake.

Input

* Line 1: Three space-separated integers: N, M, and K
* Lines 2..K+1: Line i+1 describes one submerged location with two space separated integers that are its row and column: R and C

Output

* Line 1: The number of cells that the largest lake contains. 

Sample Input

3 4 5
3 2
2 2
3 1
2 3
1 1

Sample Output

4

Source

 
 
分析:这道其实是深搜的水题啊!可是因为while(scanf("%d%d%d",&n,&m,&k) == 3)我没写==3这个条件结果一直给我超时orz。
 
//深度优先遍历 DFS  POJ 3602
#include<stdio.h>
#include<stack>
#include<string.h>
#include<cmath>
using namespace std;
int N,M,K,a,b;
const int MAXN = 110;
int form[MAXN][MAXN];
bool visit[MAXN][MAXN];
int dir[4][2]={{1,0},{-1,0},{0,1},{0,-1}};
int count;
int ans;
void DFS(int x,int y){
    int xx,yy;

    for(int i=0;i<4;i++){
        xx = x + dir[i][0];
        yy = y + dir[i][1];

        if(xx<1||yy<1||xx>N||yy>M)
            continue;
        if(form[xx][yy] && !visit[xx][yy]){
            count++;
            visit[xx][yy] = 1;
            DFS(xx,yy);
        }
    }
}
int main(){
    while(scanf("%d%d%d",&N,&M,&K)==3){
        ans = 0;
        memset(form,0,sizeof(form));
        memset(form,false,sizeof(visit));
        while(K--){
            scanf("%d%d",&a,&b);
            form[a][b] = 1;
        }
        for(int i=1;i<=N;i++){
            for(int j=1;j<=M;j++){
                if(form[i][j]&&!visit[i][j]){
                        count = 1;
                        visit[i][j]=1;
                        DFS(i,j);
                        ans = max(ans,count);
                }
            }
        }

        printf("%d\n",ans);

    }
    return 0;



}
 
 
0
0
分享到:
评论

相关推荐

    POJ1426-Find The Multiple【BFS+同余模】

    【标题】"POJ1426-Find The Multiple【BFS+同余模】"是一道来源于北京大学在线编程平台POJ的算法题目,主要涉及到了广度优先搜索(BFS)与同余模运算的知识点。这道题目要求解决的是寻找一个整数的倍数问题,可能...

    POJ1027-The Same Game

    【标题】"POJ1027 - The Same Game"是一个经典的编程竞赛题目,源自北京大学的在线编程平台POJ(Problem Online Judge)。该题目主要考察的是动态规划和矩阵链乘法的知识,要求参赛者编写程序解决一个具有策略性的...

    POJ2965-The Pilots Brothers' refrigerator

    在提供的代码文件中,"POJ2965-The Pilots Brothers' refrigerator(DFS+enum).cpp" 应该是使用DFS和枚举实现的解决方案,而 "POJ2965-The Pilots Brothers' refrigerator(DFS+Bit).cpp" 是使用DFS和位运算的版本。...

    北大POJ1163-The Triangle

    北大POJ1163-The Triangle

    POJ1163-The Triangle

    【标题】"POJ1163 - The Triangle" 是北京大学在线编程平台POJ上的一道算法题目。这道题目通常被归类为计算机科学与信息技术领域的算法问题,特别是涉及数据结构和动态规划的子领域。 【描述】该题目的解题报告详细...

    北大POJ3267-The Cow Lexicon

    北大POJ3267-The Cow Lexicon

    POJ2635-The Embarrassed Cryptographer

    【标题】"POJ2635 - The Embarrassed Cryptographer" 是一道来源于北京大学在线判题系统POJ(Problem Set)的编程题目。这道题目的主要目标是解决一个与密码学相关的问题,通常这类问题会涉及到算法设计、字符串处理...

    POJ3982-The Fibonacci sequence

    【标签】"POJ 3982 The Fibonacci sequence"是这个编程问题的标识,便于搜索和分类。POJ平台上的每个题目都有唯一的标签,方便用户查找和回顾。 斐波那契序列是计算机科学中一个基础而重要的概念,它的定义如下:...

    POJ2635-The Embarrassed Cryptographer 测试数据

    《POJ2635-The Embarrassed Cryptographer:测试数据解析与算法探讨》 POJ2635,这是一个源自NCPC(全国大学生程序设计竞赛)2005年问题D的编程挑战,名为“尴尬的密码学家”。在本文中,我们将深入探讨这个问题的...

    poj 3548 Restoring the digits.md

    poj 3548 Restoring the digits.md

    poj 1611 The Suspects 代码

    poj 1611 The Suspects 代码 并查集的应用

    poj 3554 Almost the shortest route.md

    poj 3554 Almost the shortest route.md

    POJ2151-Check the difficulty of problems

    标题“POJ2151-Check the difficulty of problems”是指一个编程竞赛题目,来源于北京大学的在线判题系统POJ(PKU Online Judge)。这个题目要求参赛者编写程序来评估问题的难度。描述中的“解题报告+AC代码”表明...

    POJ2983-Is the Information Reliable【差分约束+优化Bellman】

    《POJ2983-Is the Information Reliable:解析差分约束与优化Bellman算法》 北京大学在线编程平台上的POJ2983题目——"Is the Information Reliable",是一道涉及差分约束系统(Differential Constraint System)与...

    POJ1207-The 3n + 1 problem

    《POJ1207-The 3n + 1 problem》是北京大学在线编程平台POJ上的一道经典算法题目,其主要涉及的知识点是数论和动态规划。本题目的核心是解决著名的“Collatz Conjecture”问题,也被称为“3n+1猜想”。 3n+1猜想是...

    POJ 1054 The Troublesome Frog.rar

    标题中的“POJ 1054 The Troublesome Frog”是一个编程竞赛题目,来源于“Programming Online Judge”(POJ)平台。这个平台是程序员们练习算法和编程技能的地方,通常涉及各种数据结构和算法的问题。题目...

    POJ3267-The Cow Lexicon

    《POJ3267 - The Cow Lexicon》是一道源于北京大学在线判题系统POJ(Problem Online Judge)的编程竞赛题目。这道题目主要涉及数据结构与算法的知识,特别是字符串处理和字典树(Trie)的应用。下面将详细阐述这个...

    POJ3239-Solution to the n Queens Puzzle

    北大POJ3239-Solution to the n Queens Puzzle 解题报告+AC代码

    POJ3253-POJ3253-Fence Repair【STL优先队列】

    标题“POJ3253-POJ3253-Fence Repair【STL优先队列】”指的是一个在线编程竞赛题目,源自北京大学的在线判题系统POJ(Problem Online Judge)。该题目要求参赛者使用C++编程语言解决特定的问题,并且在解决方案中...

    poj 1611 The Suspects.md

    poj 1611 The Suspects.md

Global site tag (gtag.js) - Google Analytics