图像模糊处理(二维数组)
2023-12-13 04:49:11
给定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
代码长度限制
16 KB
时间限制
400 ms
内存限制
64 MB
C程序如下:
#include <stdio.h>
int main(void)
{
int n, m;
int i, j;
scanf("%d%d", &n, &m);
double a[n][m],b[n][m];//定义两个n行m列的数组,其中一个数组用于计算模糊值,另一个数组用于储存图像模糊处理后的值
for(int i = 0; i < n; i++)
{
for(int j = 0; j < m; j++)
{
scanf("%lf", &a[i][j]);//双重循环,输入n行m列数组中的每一个元素
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] + a[i][j - 1] + a[i][j + 1] + a[i - 1][j] + a[i + 1][j]) / 5;//双重循环,计算模糊值
}
}
for(int i = 0; i < n; i++)
{
for(int j = 0; j < m; j++)
{
if(j == m - 1)
{
printf("%.0lf", b[i][j]);//最后一列不输出空格
}
else
{
printf("%.0lf ", b[i][j]);
}
}
printf("\n");
}
return 0;
}
文章来源:https://blog.csdn.net/2302_80325489/article/details/134934951
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。 如若内容造成侵权/违法违规/事实不符,请联系我的编程经验分享网邮箱:veading@qq.com进行投诉反馈,一经查实,立即删除!
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。 如若内容造成侵权/违法违规/事实不符,请联系我的编程经验分享网邮箱:veading@qq.com进行投诉反馈,一经查实,立即删除!