【PAT乙級】1066 影象過濾
阿新 • • 發佈:2018-12-17
影象過濾是把影象中不重要的畫素都染成背景色,使得重要部分被凸顯出來。現給定一幅黑白影象,要求你將灰度值位於某指定區間內的所有畫素顏色都用一種指定的顏色替換。
輸入格式:
輸入在第一行給出一幅影象的解析度,即兩個正整數 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 25
個人理解
水題略過
程式碼實現
#include <cstdio> #include <cstring> #include <string> #include <cmath> #include <algorithm> #include <iostream> #define ll long long #define ep 1e-5 #define INF 0x7FFFFFFF using namespace std; const int maxn = 505; int main() { //初始化和輸入 int m, n, begin, end, mask, img[maxn][maxn]; cin >> m >> n >> begin >> end >> mask; //輸入圖片的同時進行過濾 for (int i = 0; i < m; i ++) { for (int j = 0; j < n; j ++) { int color; cin >> color; if (color >= begin && color <= end) color = mask; img[i][j] = color; } } //輸出 for (int i = 0; i < m; i ++) { for (int j = 0; j < n; j ++) { printf("%03d", img[i][j]); if (j < n-1) cout << " "; } cout << endl; } return 0; }
總結 學習不息,繼續加油