概述
1128:图像模糊处理
时间限制: 1000 ms 内存限制: 65536 KB
提交数: 17548 通过数: 7368
【题目描述】
给定n行m列的图像各像素点的灰度值,要求用如下方法对其进行模糊化处理:
1.四周最外侧的像素点灰度值不变;
2.中间各像素点新灰度值为该像素点及其上下左右相邻四个像素点原灰度值的平均(舍入到最接近的整数)。
【输入】
第一行包含两个整数n和m,表示图像包含像素点的行数和列数。1≤n≤100,1≤m≤100。
接下来n行,每行m个整数,表示图像的每个像素点灰度。相邻两个整数之间用单个空格隔开,每个元素均在0∼255之间。
【输出】
n行,每行m个整数,为模糊处理后的图像。相邻两个整数之间用单个空格隔开。
【输入样例】
4 5
100 0 100 0 50
50 100 200 0 0
50 50 100 100 200
100 100 50 50 100
【输出样例】
100 0 100 0 50
50 80 100 60 0
50 80 100 90 200
100 100 50 50 100
思路:四周最外侧的像素点灰度值不变,去掉最外层i=2开始循环,该像素点和其上下左右相邻四个像素点(一共5个点)原灰度值的平均。Round()函数返回一个数值,该数值是按照指定的小数位数进行四舍五入运算的结果,其包含在cmath头文件中(#include)。
#include<iostream>
#include<cmath>
using namespace std;
int main()
{
int m,n;
int a[101][101];
double b[101][101];
int i,j;
cin >> n >> m;
for(i = 1;i <= n;i++)
for(j = 1 ;j <= m;j++)
{
cin >> a[i][j];
b[i][j] = a[i][j];
}
for(i = 2;i <= n-1;i++)//去掉最外层i=2,j=2,开始循环 分别至 n-1 ,m-1
for(j = 2;j <= m-1;j++)
// if((i == 1||i==n||j==1||j==m)) b[i][j]=a[i][j];
b[i][j] = round((a[i][j] + a[i-1][j] + a[i+1][j] + a[i][j-1] + a[i][j+1])/ 5.0);
for(i = 1;i <= n;i++)
{
for(j = 1;j <= m;j++)
cout << b[i][j] <<" ";
cout << endl;
}
return 0;
}
最后
以上就是苗条帅哥为你收集整理的第五章 数 组-1128:图像模糊处理的全部内容,希望文章能够帮你解决第五章 数 组-1128:图像模糊处理所遇到的程序开发问题。
如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。
本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
发表评论 取消回复