PAT-B 1066 影象過濾【陣列】

Enjoy_process發表於2019-02-25

                                              PAT-B 1066 影象過濾

                 https://pintia.cn/problem-sets/994805260223102976/problems/994805266514558976

 

 

題目

影象過濾是把影象中不重要的畫素都染成背景色,使得重要部分被凸顯出來。現給定一幅黑白影象,要求你將灰度值位於某指定區間內的所有畫素顏色都用一種指定的顏色替換。

輸入

輸入在第一行給出一幅影象的解析度,即兩個正整數 M 和 N(0<M,N≤500),另外是待過濾的灰度值區間端點 A 和 B(0≤A<B≤255)、以及指定的替換灰度值。隨後 M 行,每行給出 N 個畫素點的灰度值,其間以空格分隔。所有灰度值都在 [0, 255] 區間內。

輸出

輸出按要求過濾後的影象。即輸出 M 行,每行 N 個畫素灰度值,每個灰度值佔 3 位(例如黑色要顯示為 000),其間以一個空格分隔。行首尾不得有多餘空格。

樣例輸入

3 5 100 150 0
3 189 254 101 119
150 233 151 99 100
88 123 149 0 255

樣例輸出

003 189 254 000 000
000 233 151 099 000
088 000 000 000 255

分析

簡單陣列處理,具體細節看程式。

C++程式

#include<iostream>

using namespace std;

const int N=505;

int a[N][N];

int main()
{
	int n,m,A,B,C;
	scanf("%d%d%d%d%d",&n,&m,&A,&B,&C);
	for(int i=0;i<n;i++)
	  for(int j=0;j<m;j++)
	  {
	  	scanf("%d",&a[i][j]);
	  	if(A<=a[i][j]&&a[i][j]<=B)//灰度值位於區間[A,B]內 
	  	  a[i][j]=C;
	  }
	for(int i=0;i<n;i++)
	{
		for(int j=0;j<m;j++)
		{
			if(j) printf(" ");
			printf("%03d",a[i][j]);
		}
		printf("\n");
	}
	return 0;
}

 

相關文章