百练noi 19: 肿瘤检测
19:肿瘤检测
- 查看
- 提交
- 统计
- 提问
- 总时间限制:
- 1000ms 内存限制:
- 65536kB
- 描述
-
一张CT扫描的灰度图像可以用一个N*N(0 < N <= 100)的矩阵描述,矩阵上的每个点对应一个灰度值(整数),其取值范围是0-255。我们假设给定的图像中有且只有一个肿瘤。在图上监测肿瘤的方法如下:如果某个点对应的灰度值小于等于50,则这个点在肿瘤上,否则不在肿瘤上。我们把在肿瘤上的点的数目加起来,就得到了肿瘤在图上的面积。任何在肿瘤上的点,如果它是图像的边界或者它的上下左右四个相邻点中至少有一个是非肿瘤上的点,则该点称为肿瘤的边界点。肿瘤的边界点的个数称为肿瘤的周长。现在给定一个图像,要求计算其中的肿瘤的面积和周长。
输入 - 输入第一行包含一个正整数N(0 < N <= 100),表示图像的大小;接下来N行,每行包含图像的一行。图像的一行用N个整数表示(所有整数大于等于0,小于等于255),两个整数之间用一个空格隔开。 输出
- 输出只有一行,该行包含两个正整数,分别为给定图像中肿瘤的面积和周长,用一个空格分开。 样例输入
-
6 99 99 99 99 99 99 99 99 99 50 99 99 99 99 49 49 50 51 99 50 20 25 52 99 40 50 99 99 99 99 99 99 99 99 99 99 样例输出 -
9 8 来源 - 计算概论05-模拟考试1
- 代码:
-
#include#include #include using namespace std; const int N = 105; int matrix[N][N]; int go[][2] = {1,0,-1,0,0,1,0,-1}; int main(){int n,area = 0, len = 0;scanf("%d",&n);for(int i = 0; i < n; ++i){for(int j = 0; j < n; ++j){scanf("%d",&matrix[i][j]);if(matrix[i][j] <= 50){area++;if(i == 0 || j == 0 || i == n-1 || j == n -1)len++; }} }for(int i = 1; i < n - 1; ++i){for(int j = 1; j < n-1; ++j){if(matrix[i][j] <= 50){for(int k = 0; k < 4; ++k){if(matrix[i + go[k][0]][j + go[k][1]] > 50){len++; break;}}}}}printf("%d %d\n",area,len);return 0; }
-
本文来自互联网用户投稿,文章观点仅代表作者本人,不代表本站立场,不承担相关法律责任。如若转载,请注明出处。 如若内容造成侵权/违法违规/事实不符,请点击【内容举报】进行投诉反馈!
