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;
}
posted @ 2021-07-19 07:33  Jijidawang  阅读(11)  评论(0编辑  收藏  举报  来源