勘探油田

<pre name="code" class="cpp">#include <iostream>
#include <cstring>
using namespace std;
char a[100][100];
int b[100][100],n,m;
int x[]={0,-1,-1,-1,0,1,1,1};
int y[]={1,1,0,-1,-1,-1,0,1};
void dfs(int i,int j)//深度搜索
{
	int tx,ty,k;
	b[i][j]=0;
	for (k=0;k<8;++k)
	{
		tx=i+x[k];
		ty=j+y[k];
		if(a[tx][ty]=='@'&&tx>0&&tx<=n&&ty>0&&ty<=m&&b[tx][ty]==1)
		{
			dfs(tx,ty);
		}
	}
}
int queue[10000][2];
void bfs(int i,int j)//广度搜索
{
	int k,tx,ty,cx,cy;
	int head=0,tail=0;
	queue[tail][0]=i;
	queue[tail][1]=j;
	tail++;
	b[i][j]=0;
	while(head<tail)
	{
		cx=queue[head][0];
		cy=queue[head][1];
		head++;
		for (k=0;k<8;++k)
		{
			tx=cx+x[k];
			ty=cy+y[k];
			if (tx>0&&tx<=n&&ty>0&&ty<=m&&b[tx][ty]==1&&a[tx][ty]=='@')
			{
				queue[tail][0]=tx;
				queue[tail][1]=ty;
				tail++;
				b[tx][ty]=0;
			}
		}
	}
}
int main()
{
	int i,j,sum;
	while(true)
	{
		cin >> n >> m;
		if (n==0&&m==0)
		{
			break;
		}
		for (i=1;i<=n;++i)
		{
			for(j=0;j<=m;++j)
			{
				b[i][j]=1;
			}
		}
		sum=0;
		for (i=1;i<=n;++i)
		{
			cin >> a[i] ;
		}
		for (i=1;i<=n;++i)
		{
			for (j=1;j<=m;++j)
			{
				if (a[i][j]=='@'&&b[i][j]==1)
				{
					sum++;
					/*dfs(i,j);*/
					bfs(i,j);
				}
			}
		}
		cout << sum << endl;
	}
	return 0;
}

勘探油田

Description

某石油勘探公司正在按计划勘探地下油田资源。他们工作在一片长方形的地域中,首先将该地域划分为许多小正方形区域,然后使用探测设备分别探测每一块小正方形区域是否有油。若在一块小正方形区域中探测到有油,则标记为’@’,否则标记为’*’。如果两个相邻区域都为1,那么它们同属于一个石油带,一个石油带可能包含很多小正方形区域,而你的任务是要确定在一片长方形地域中有多少个石油带。
所谓相邻,是指两个小正方形区域上下、左右、左上右下或左下右上同为’@’。

Input

输入数据将包含一些长方形地域数据,每个地域数据的第一行有两个正整数m和n,表示该地域为m*n个小正方形所组成,如果m为0,表示所有输入到此结束。否则,后面m(1≤m≤100)行数据,每行有n(1≤n≤100)个字符,每个字符为’@’或’*’,表示有油或无油。每个长方形地域中,’@’的个数不会超过100。

Output

每个长方形地域,输出油带的个数,每个油带值占独立的一行。油带值不会超过100。

Sample Input

  1. 1 1
  2. *
  3. 3 5
  4. *@*@*
  5. **@**
  6. *@*@*
  7. 1 8
  8. @@****@*
  9. 5 5
  10. ****@
  11. *@**@
  12. *@**@
  13. @@@*@
  14. @@**@
  15. 0 0

Sample Output

  1. 0
  2. 1
  3. 2
  4. 2
时间: 2024-10-21 05:40:57

勘探油田的相关文章

【题解】Reach-Top 1115 勘探油田

题目描述 某石油勘探公司正在按计划勘探地下油田资源,工作在一片长方形的地域中.他们首先将该地域划分为许多小正方形区域,然后使用探测设备分别探测每一块小正方形区域内是否有油.若在一块小正方形区域中探测到有油,则标记为'\(@\)',否则标记为'\(*\)'.如果两个相邻区域都为\(1\),那么它们同属于一个石油带,一个石油带可能包含很多小正方形区域,而你的任务是要确定在一片长方形地域中有多少个石油带. 所谓相邻,是指两个小正方形区域上下.左右.左上右下或左下右上同为'\(@\)'. 输入 输入数据

Schlumberger Techlog 2013.3 Win64 油田测井解释+Schlumberger ECLIPSE 2015.1 油藏模拟中文最新版

Schlumberger Techlog 2013.3 Win64 油田测井解释+Schlumberger ECLIPSE 2015.1 油藏模拟中文最新版二维配管软件qpiping3.2+风险分析DNV Phast Risk v6.7+CAESAR II 2014 工艺配管Zeataline.PipeData.Pro.v10.0.21风险分析DNV Phast Risk v6.7-ISO 1DVDCAESAR II 2014 win32 64支持win7 win8 管道设计应力分析软件CAES

从数字油田的关键问题说开去

昨天在“智能数字油田开放论坛”上忍不住说了一句“数据元.元数据不是解决数字油田的关键问题”就干活去了,后来发现被袁教授追问了一句“那什么才是数字油田的关键问题?”,经这么一追问,我还真一下子说不出哪些算是关键问题,这两天就根据自己从事的一些工作所掌握的情况来扯上几句. 1.数字油田的关键技术? 虽然以前承担了<数字油气田关键技术研究>863项目中的一个课题工作,但惭愧的是被赶鸭子上架,并没有理清哪些算是关键技术,也没有弄出什么高级理论,几个人整天忙着写材料.汇报.开会.验收.审计,干活的时候找

Schlumberger Oil Field Manager(OFM) 2014.1-ISO 1CD(油田日常监控和管理软件包)

Schlumberger Oil Field Manager(OFM) 2014.1-ISO 1CD(油田日常监控和管理软件包)Schlumberger Oil Field Manager(OFM) 2012.1-ISO 1CD(油田日常监控和管理软件包)Merak Peep 2007.1-ISO 1DVD(经济评价和产量递减分析软件,用于测定油气开采方案的经济可行性) Petrel.v2009.1-ISO 1CD(勘探开发一体化油藏综合描述软件) Pipesim 2008.1-ISO 1CD(

油气勘探开发从业务到IT的一体化解决方案

油气勘探开发 从业务到IT的一体化解决方案 ----油气勘探开发"十三五"信息化规划建议 大江东去 摘要: 在刚过去的3个5年规划中,中国石油石化行业信息化取得了巨大的成就,完成了从"企业信息化"到"信息化企业"进程.但到目前为止,IT规划还没有真正从企业架构导入,导致IT规划与企业实际业务存在一定的脱节问题. 而在进行IT投资时,都会跳过企业架构这个关键的环节直接进入IT项目建设.这样必然会导致烟囱式的建设方式,单片电路式的应用系统,旧的信息孤

题目--oil Deposits(油田) 基础DFS(深度搜索)

上一次基本了解了下BFS,这次又找了个基本的DFS题目来试试水,DFS举个例子来说就是 一种从树的最左端开始一直搜索到最底端,然后回到原端再搜索另一个位置到最底端,也就是称为深度搜索的DFS--depth first search,话不多说,直接上题了解: Description:某石油勘探公司正在按计划勘探地下油田资源,工作在一片长方形的地域中.他们首先将该地域划分为许多小正方形区域,然后使用探测设备分别探测每一块小正方形区域内是否有油.若在一块小正方形区域中探测到有油,则标记为’@’,否则标

Petrel.v2009.1-ISO 1CD(勘探开发一体化油藏综合描述软件)

PVTsim v18.0-ISO 1CD(多用途PVT模拟软件) PAULIN产品: PRG PAULIN v2007 (专业压力容器和管道有限元) Schlumberger产品: Merak Peep 2007.1-ISO 1DVD(经济评价和产量递减分析软件,用于测定油气开采方案的经济可行性) Pipesim 2008.1-ISO 1CD(PIPESIM 产品系统分析软件可模拟稳态.多相流的油气系统.单独的PIPESIM模块可进行大范围 的分析,包括:油井模型.节点分析.人工智能提升优化.管

hdu 1241 油田 裸DFS

题意:@代表油田 8个方向上还有@就相连 相当于求图中连通子图的个数Sample Input1 1 // n m*3 5*@*@***@***@*@*1 8@@****@*5 5 ****@*@@*@*@**@@@@*@@@**@0 0 Sample Output0122 1 #include<iostream> 2 #include<cstdio> 3 #include<cstring> 4 #include<string> 5 #include<a

智能油田

大数据与地理信息,对于大数据,目前采.存.传都不是问题, 最大的问题是大数据的处理(解译)问题. 对于复杂性.需要重组数据的实时分析的智能的能力. 智慧没有上限, 智慧油田没有哪一天可说建成, 是需要持续发展的过程 . A11建设标准,实施顶层设计. 智能油田探索与设想,智能油藏数据诊断,实现油藏动态管理Hadoop:开源 数据整合,智能预测 多井集联通信,基于 Zigbee技术,是基本成熟的技术了,不是很新.