【最简便解法】1066 图像过滤 (15分)
生活随笔
收集整理的這篇文章主要介紹了
【最简便解法】1066 图像过滤 (15分)
小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.
立志用更少的代碼做更高效的表達
Pat乙級最優(yōu)化代碼+題解+分析匯總——>傳送門
圖像過濾是把圖像中不重要的像素都染成背景色,使得重要部分被凸顯出來。現(xiàn)給定一幅黑白圖像,要求你將灰度值位于某指定區(qū)間內(nèi)的所有像素顏色都用一種指定的顏色替換。
輸入格式:
輸入在第一行給出一幅圖像的分辨率,即兩個正整數(shù) M 和 N(0<M,N≤500),另外是待過濾的灰度值區(qū)間端點 A 和 B(0≤A<B≤255)、以及指定的替換灰度值。隨后 M 行,每行給出 N 個像素點的灰度值,其間以空格分隔。所有灰度值都在 [0, 255] 區(qū)間內(nèi)。
輸出格式:
輸出按要求過濾后的圖像。即輸出 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
#include<stdio.h> int main() {int M, N, Min, Max, goal;scanf("%d%d%d%d%d", &M, &N, &Min, &Max, &goal);for(int i = 0; i < M; i++) {for(int j = 0; j < N; j++) {int x; scanf("%d", &x);if(x>=Min && x<=Max) x = goal;if(j != 0) putchar(' ');printf("%03d", x);}putchar('\n');}return 0; }
耗時
每日一句
每一個不曾起舞的日子,都是對生命的辜負
超強干貨來襲 云風專訪:近40年碼齡,通宵達旦的技術人生總結
以上是生活随笔為你收集整理的【最简便解法】1066 图像过滤 (15分)的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 【高效解法】1065 单身狗 (25分)
- 下一篇: 【测试点分析】1067 试密码 (20分