Oil Deposits——在图中找油田

本文探讨了GeoSurvComp公司如何使用地质调查方法检测地下油田,并详细解释了识别油田的具体步骤,包括创建网格划分土地、单独分析每个地块以及使用感应设备判断是否含有油土。通过分析相邻地块来确定它们是否属于同一油田,最终计算出不同油田的数量。

  Oil Deposits 

The GeoSurvComp geologic survey company is responsible for detecting underground oil deposits. GeoSurvComp works with one large rectangular region of land at a time, and creates a grid that divides the land into numerous square plots. It then analyzes each plot separately, using sensing equipment to determine whether or not the plot contains oil.

A plot containing oil is called a pocket. If two pockets are adjacent, then they are part of the same oil deposit. Oil deposits can be quite large and may contain numerous pockets. Your job is to determine how many different oil deposits are contained in a grid.

Input 

The input file contains one or more grids. Each grid begins with a line containing  m  and  n , the number of rows and columns in the grid, separated by a single space. If  m  = 0 it signals the end of the input; otherwise  $1 \le m \le 100$  and  $1 \le n \le 100$ . Following this are  m  lines of  n  characters each (not counting the end-of-line characters). Each character corresponds to one plot, and is either `  * ', representing the absence of oil, or `  @ ', representing an oil pocket.

Output 

For each grid, output the number of distinct oil deposits. Two different pockets are part of the same oil deposit if they are adjacent horizontally, vertically, or diagonally. An oil deposit will not contain more than 100 pockets.

Sample Input 

1 1
*
3 5
*@*@*
**@**
*@*@*
1 8
@@****@*
5 5
****@
*@@*@
*@**@
@@@*@
@@**@
0 0

Sample Output 

0
1
2
2


题意:给出一个m*n个图,*代表没有油田,@代表有油田,问在这块地图中一共有多少块大的油田?注意:@的八个方向有@就相当于在同一块油田中。

做了很多遍的题目了,DFS直接能过,当初学的时候还很模糊,时隔一年,随着理解的越来越深,发现这种小题可以很快就能A掉了,心情瞬间好了。废话不多说,直接上代码:

#include <stdio.h>
#include <string.h>
#include <math.h>

int fx[8] = {-1,-1,0,1,1,1,0,-1};
int fy[8] = {0,1,1,1,0,-1,-1,-1};
char mapp[106][106];

void DFS(int a,int b)
{
    mapp[a][b] = '*';
    int i;
    for(i = 0; i < 8; i++)
    {
        if(a+fx[i]>=0&&b+fy[i]>=0&&mapp[a+fx[i]][b+fy[i]] == '@')
        {
            DFS(a+fx[i],b+fy[i]);
        }
    }
}

int main()
{
    int n,m,i,j,num;
    while(~scanf("%d%d",&m,&n),m)
    {
        num = 0;
        for(i = 0; i < m; i++)
        {
            scanf("%s",mapp[i]);
        }
        for(i = 0; i < m; i++)
        {
            for(j = 0; j < n; j++)
            {
                if(mapp[i][j] == '@')
                {
                    DFS(i,j);
                    num++;
                }
            }
        }
        printf("%d\n",num);
    }
    return 0;
}



下载方式:https://renmaiwang.cn/s/t0445 在时序发生器设计实验中,如何达成T4至T1的生成? 时序发生器的构建可以通过运用一个4位循环移位寄存器来达成T4至T1的输出。 具体而言:- **CLR(清除)**: 作为全局清零信号,当CLR呈现低电平状态时,所有输出(涵盖T1至T4)皆会被清除。 - **STOP**: 在T4脉冲的下降沿时刻,若STOP信号处于低电平状态,则T1至T4会被重置。 - **启动流程**: 当启动信号START处于高电平,并且STOP为高电平时,移位寄存器将在每个时钟的上升沿向左移动一位。 移位寄存器的输出端对应了T4、T3、T2、T1。 #### 2. 时序发生器如何调控T1至T4的波形形态? 时序发生器通过以下几个信号调控T1至T4的波形形态:- **CLR**: 当CLR处于低电平状态时,所有输出均会被清零。 - **STOP**: 若STOP信号为低电平,且在T4脉冲的下降沿时刻,所有输出同样会被清零。 - **START**: 在START信号有效(通常为高电平),并且STOP为高电平时,移位寄存器启动,从而产生环形脉冲输出。 ### 微程序控制器实验#### 3. 微程序控制器实验中的四条机器指令及其对应的微程序段指定的机器指令及其关联的微程序段如下:- **NOP**: 00- **R0->B**: 04- **A+B->R0**: 05- **P<1>**: 30- **IN->R0**: 32- **R0->OUT**: 33- **HLT**: 35#### 4. 微程序段中的微操作/微命令序列针对每条微指令,其对应的微操作或微命令序列如下:- **IN->R0**: 输入(IN)单元的数据被...
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值