题目描述:
图像过滤是把图像中不重要的像素都染成背景色,使得重要部分被凸显出来。现给定一幅黑白图像,要求你将灰度值位于某指定区间内的所有像素颜色都用一种指定的颜色替换。
输入格式:
输入在第一行给出一幅图像的分辨率,即两个正整数 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
----------------------------------------------------------答题区----------------------------------------------------------
#include <iostream>
using namespace std;
int main()
{
int row,col,min_qujian,max_qujian,daiti_value,value,flag=1;
scanf("%d %d %d %d %d",&row,&col,&min_qujian,&max_qujian,&daiti_value);
for(int i=0;i<row;i++)
{
for(int j=0;j<col;j++)
{
scanf("%d",&value);
if(value>=min_qujian && value<=max_qujian)
{
value = daiti_value;
}
if(flag==1)
{
printf("%03d",value);
}
else if(flag==col)
{
printf(" %03d\n",value);
}
else
{
printf(" %03d",value);
}
flag++;
}
flag = 1;
}
return 0;
}
已经考完了乙级,虽然结果不是很理想,大家可以看一下我的经验贴https://blog.csdn.net/qq_40612211/article/details/100973477。
维护了一个PAT测试点问题的共享文档,欢迎大家把遇到的问题写在上面。
一起写文档:https://yiqixie.com/d/home/fcACe6xZ2aroPxFQrQZ05Cw32
github链接:https://github.com/Makerdd/PAT-yiji