给定n行m列的图像各像素点的灰度值,要求用如下方法对其进行模糊化处理:
四周最外侧的像素点灰度值不变;
中间各像素点新灰度值为该像素点及其上下左右相邻四个像素点原灰度值的平均(舍入到最接近的整数)。
第一行包含两个整数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
_____________________________________________________________________________
日常发作业题解。?
写作不易,点个赞呗!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!?
_____________________________________________________________________________
#include <bits/stdc++.h>
using namespace std;
int a[10005][10005],n,m;
int main(){
cin>>n>>m;
for(int i=1;i<=n;i++){
for(int j=1;j<=m;j++){
cin>>a[i][j];
}
}
for(int i=1;i<=n;i++){
for(int j=1;j<=m;j++){
if(i!=1&&j!=1&&i!=n&&j!=m){
cout<<(int)((a[i+1][j]+a[i][j]+a[i][j-1]+a[i][j+1]+a[i-1][j])/5.0+0.5)<<" ";//5.0为让除法小数化,加上0.5让他四舍五入此处比较妙可以深思。
}
else cout<<a[i][j]<<" ";//边框的数题目说不用动。
}
cout<<endl;
}
}
?