B2108 图像模糊处理
前置芝士
round(double x)
:将 $x$ 四舍五入成整数。
思路
建一个新矩阵用来存放答案,枚举一遍原矩阵。
如果枚举到的点在边上,就直接把值赋给新矩阵。
否则就取原矩阵的点的上下左右中的平均值。
因为按顺序处理新矩阵时,下方和右方都是0,
所以不能用新矩阵的平均值。
代码
#include <iostream>
#include <cmath>
using namespace std;
double a[1001][1001], b[1001][1001], n, m;
int main()
{
cin >> n >> m;
for(int i = 0;i < n;++i)
for(int j = 0;j < m;++j)
cin >> a[i][j], b[i][j] = a[i][j];
for(int i = 0;i < n;++i)
for(int j = 0;j < m;++j)
if(!i || !j || i == n - 1 || j == m - 1)
b[i][j] = a[i][j];
else
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(int i = 0;i < n;++i)
{
for(int j = 0;j < m;++j)
cout << b[i][j] << " ";
cout << endl;
}
return 0;
}