图像模糊处理(二维数组)

2023-12-13 04:49:11

给定n行m列的图像各像素点的灰度值,要求用如下方法对其进行模糊化处理:

  1. 四周最外侧的像素点灰度值不变;

  2. 中间各像素点新灰度值为该像素点及其上下左右相邻四个像素点原灰度值的平均(舍入到最接近的整数)。

输入格式:

第一行包含两个整数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
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。