一本通C++ 1128 图像模糊处理

该程序实现了一种图像模糊化处理方法,保持图像四周像素点灰度不变,中间部分的像素点新值为其相邻四个点的灰度平均值(四舍五入)。通过使用两个二维数组a和b,先读取原始图像数据存储在a中,然后计算新的灰度值并存入b,最后输出处理后的图像数据。
摘要由CSDN通过智能技术生成

题目描述:给定m行n列的图像各像素点的灰度值,要求用如下方法对其进行模糊化处理:1.四周最外侧的像素点灰度值不变;2.中间各像素点新灰度值为该像素点及其上下左右相邻四个像素点原灰度值的平均(舍入到最接近的整数)。

输入格式第一行包含两个整数n和m,表示图像包含像素点的行数和列数。1≤n≤100,1≤m≤100。接下来n行,每行m个整数,表示图像的每个像素点灰度。相邻两个整数之间用单个空格隔开,每个元素均在0~255之间。

输出格式:n行,每行m个整数,为模糊处理后的图像。相邻两个整数之间用单个空格隔开。

输入数据1:

4 5
100 0 100 0 50
50 100 200 0 0
50 50 100 100 200
100 100 50 50 100

输出数据1

100 0 100 0 50
50 80 100 60 0
50 80 100 90 200
100 100 50 50 100

  从题目上来看,这是一道二维数组的题,但直接操作会导致覆盖原数组,所以我们需要做两个二维数组a和b。

int a[111][111];
int b[111][111];

输入n和m的值且输入、5、1个二维数组a赋值给b数组。(边框)

int n,m;
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];
    }
}

赋值b数组,a数组四周加自己除五并进行四舍五入运算 b数组进行储存

for(int i=1;i<n-1;i++){
    for(int j=1;j<m-1;j++){
        b[i][j]=(a[i][j+1]+a[i-1][j]+a[i+1][j]+a[i][j-1]+a[i][j])/5.0+0.5;
    }
}

最后输出。

完整代码:

#include<bits/stdc++.h>
using namespace std;
int a[111][111];
int b[111][111];
int main()
{
    int n,m;
    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=1;i<n-1;i++){
        for(int j=1;j<m-1;j++){
            b[i][j]=(a[i][j+1]+a[i-1][j]+a[i+1][j]+a[i][j-1]+a[i][j])/5.0+0.5;
        }
    }
    for(int i=0;i<n;i++){
        for(int j=0;j<m;j++){
            cout<<b[i][j]<<" ";
        }
        cout<<endl;
    }
    return 0;
}

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值