L3-004. 肿瘤诊断

在诊断肿瘤疾病时,计算肿瘤体积是很重要的一环。给定病灶扫描切片中标注出的疑似肿瘤区域,请你计算肿瘤的体积。

输入格式:

输入第一行给出4个正整数:M、N、L、T,其中M和N是每张切片的尺寸(即每张切片是一个M×N的像素矩阵。最大分辨率是1286×128);L(<=60)是切片的张数;T是一个整数阈值(若疑似肿瘤的连通体体积小于T,则该小块忽略不计)。

最后给出L张切片。每张用一个由0和1组成的M×N的矩阵表示,其中1表示疑似肿瘤的像素,0表示正常像素。由于切片厚度可以认为是一个常数,于是我们只要数连通体中1的个数就可以得到体积了。麻烦的是,可能存在多个肿瘤,这时我们只统计那些体积不小于T的。两个像素被认为是“连通的”,如果它们有一个共同的切面,如下图所示,所有6个红色的像素都与蓝色的像素连通。【这句话是重点,还有就是像素是什么鬼?!看了好长时间,最后大致看明白了!题意需要审清楚!还有就是切片的问题,题目中给的切片是摞起来一层一层的?还是在同一个平面上平着切下的呢?!——后来查了查资料原来是切片一层一层切下去的!/逃】

输出格式:

在一行中输出肿瘤的总体积。

输入样例:

......


  1. #include<iostream>
  2. #include<stdio.h>
  3. #include<string.h>
  4. #include<math.h>
  5. #include<algorithm>
  6. #include<queue>
  7. #include<set>
  8. #include<vector>
  9. #include<string>
  10. #include<stack>
  11. #define inf 0x3f3f3f3f
  12. using namespace std; //L3-004, 肿瘤诊断
  13. #define N 200
  14. #define ll long long
  15. int mp[][N][N];//这里不能开的太大,太小会WA,太大会炸!
  16. int vis[][N][N];
  17. int dir[][]={ {,,},{,,},{,,},{-,,},{,-,},{,,-} };
  18. struct node{
  19. int x,y,z;
  20. node(int x=,int y=,int z=):x(x),y(y),z(z){}//类似Java的类的构造方法,可以让 st=node(i0,j0,k0) 直接实现!!
  21. };
  22. int m,n,l,T;//l表示层数,T表示阈值(表示组合成联通块的最小合格体积)
  23. int bfs(int i0,int j0,int k0){//以下为bfs常规基本套路,不多解释
  24. int ans=;
  25. node st,now,ne;
  26. st=node(i0,j0,k0);
  27. queue<node>Q;
  28. Q.push(st);
  29. vis[i0][j0][k0]=;
  30. while(Q.size()>){
  31. now=Q.front();
  32. Q.pop();
  33. for(int i=;i<;i++){
  34. ne.x=now.x+dir[i][];
  35. ne.y=now.y+dir[i][];
  36. ne.z=now.z+dir[i][];
  37.  
  38. if(ne.x<||ne.x>l||ne.y<||ne.y>m||ne.z<||ne.z>n)
  39. continue;
  40. else if(vis[ne.x][ne.y][ne.z]==||mp[ne.x][ne.y][ne.z]==)
  41. continue;
  42. else{
  43. vis[ne.x][ne.y][ne.z]=;
  44. Q.push(ne);
  45. ans++;
  46. }
  47. }
  48. }
  49. return (ans>=T?ans:);
  50. }
  51. int main(){
  52.  
  53. int num;
  54. scanf("%d%d%d%d",&m,&n,&l,&T);
  55. for(int i=;i<=l;i++){
  56. for(int j=;j<=m;j++){
  57. for(int k=;k<=n;k++){
  58. scanf("%d",&mp[i][j][k]);
  59. }
  60. }
  61. }
  62. memset(vis,,sizeof(vis));
  63. int ans=;
  64. for(int i=;i<=l;i++){
  65. for(int j=;j<=m;j++){
  66. for(int k=;k<=n;k++){
  67. if(mp[i][j][k]==&&!vis[i][j][k])//符合两个条件,即可开始
  68. ans+=bfs(i,j,k);
  69. }
  70. }
  71. }
  72. printf("%d\n",ans);
  73.  
  74. return ;
  75. }

(带点注释~~)

DFS不知道行不行,具体自行试试!

 

【经典/基础BFS+略微复杂的题意】PAT-L3-004. 肿瘤诊断的更多相关文章

  1. 一道很经典的 BFS 题

    一道很经典的 BFS 题 想认真的写篇题解. 题目来自:https://www.luogu.org/problemnew/show/P1126 题目描述 机器人移动学会(RMI)现在正尝试用机器人搬运 ...

  2. HDU 1372 Knight Moves(最简单也是最经典的bfs)

    传送门: http://acm.hdu.edu.cn/showproblem.php?pid=1372 Knight Moves Time Limit: 2000/1000 MS (Java/Othe ...

  3. pat 甲级 团体天梯 L3-004. 肿瘤诊断

    L3-004. 肿瘤诊断 时间限制 400 ms 内存限制 65536 kB 代码长度限制 8000 B 判题程序 Standard 作者 陈越 在诊断肿瘤疾病时,计算肿瘤体积是很重要的一环.给定病灶 ...

  4. PAT天梯赛练习题——L3-004. 肿瘤诊断(三维连通块并查集)

    L3-004. 肿瘤诊断 时间限制 400 ms 内存限制 65536 kB 代码长度限制 8000 B 判题程序 Standard 作者 陈越 在诊断肿瘤疾病时,计算肿瘤体积是很重要的一环.给定病灶 ...

  5. POJ 3287 (基础BFS) Catch That Cow

    这是做的第一道BFS,很基础很简单的题目 广度优先搜索算法如下:(用QUEUE)(1) 把初始节点S0放入Open表中:(2) 如果Open表为空,则问题无解,失败退出:(3) 把Open表的第一个节 ...

  6. 入门经典——基础数据结构专题(List)

    UVA127 链接:https://uva.onlinejudge.org/index.php?option=com_onlinejudge&Itemid=8&page=show_pr ...

  7. HDU 1175 连连看(超级经典的bfs之一)

    传送门: http://acm.hdu.edu.cn/showproblem.php?pid=1175 连连看 Time Limit: 20000/10000 MS (Java/Others)     ...

  8. HDU 1180 诡异的楼梯(超级经典的bfs之一,需多回顾)

    传送门: http://acm.hdu.edu.cn/showproblem.php?pid=1180 诡异的楼梯 Time Limit: 2000/1000 MS (Java/Others)     ...

  9. poj1979【基础bfs/dfs】

    挑战习题搜索-1 题意: 给定起点,然后求一个可以到达的数量,位置"."都可以走.每次应该是上下左右都可以走. 思路: 这题应该DFS更好写,但是BFS也可以写吧. 好久没写了- ...

随机推荐

  1. thinkphp5 笔记 模型调用

    模型 useapp\index\model\Article as ArticleModel; //静态调用更新 $Article= ArticleModel::); $Article->name ...

  2. c++ 在Ubuntu系统中使用access函数

    include<iostream> #include<stdlib.h> #include<stdio.h> #include<unistd.h> us ...

  3. k8s nfs

    1 yum install -y nfs-utils-* 2 mkdir /home/data 3 vim /etc/exports /home/data 10.0.0.0/24(rw,async,n ...

  4. dotnet core use MangoDB

    安装MangoDB 同样我这边再次使用Docker, 方便快捷: # 拉取镜像 docker pull mongo # 运行镜像 docker run -d -p 37017:27017 --name ...

  5. 033 Android App启动的闪屏效果+新手向导(多个图片滑动效果)+ViewPager使用

    1.目标效果 App启动时,出现闪屏效果(利用动画实现). App新手使用时,会出现新手向导效果. 2.XML页面布局 (1)闪屏页面 <?xml version="1.0" ...

  6. [转帖]微软 SQ1 参数一览:8 核 Kryo 495,Adreno 685 GPU

    微软 SQ1 参数一览:8 核 Kryo 495,Adreno 685 GPU http://www.myzaker.com/article/5d989ef68e9f0977765e5506/ 微软发 ...

  7. Java调用SqlLoader将大文本导入数据库

    Java调用SqlLoader将大文本导入数据库 业务场景:将一千万条数据,大约500M的文本文档的数据导入到数据库 分析:通过Java的IO流解析txt文本文档,拼接动态sql实现insert入库, ...

  8. Python re模块学习

    这是re模块与正则的结合 re模块提供的函数 1.match  尝试在字符串的开头应用该模式,返回匹配对象,如果没有找到匹配,则为None. import re str1 = "Why ar ...

  9. PowerBuilder学习笔记之2PowerScript语言(三)

    教材地址:https://wenku.baidu.com/view/1e82d26925c52cc58ad6be05.html?sxts=1565679996440 2.6嵌入式SQL语句 2.6.1 ...

  10. Spring Cloud 基于Consul 实现配置服务

    Spring Cloud体系中提供了Config组件来进行配置服务管理.而Consul除了提供服务注册与发现功能外,同时也提供配置管理功能.本位将介绍如何结合Spring Cloud + Consul ...