【蓝桥杯 2021】图像模糊

图像模糊

题目描述

小蓝有一张黑白图像,由 n×m 个像素组成,其中从上到下共 n 行,每行从左到右 m 列。每个像素由一个 0 到 255 之间的灰度值表示。

现在,小蓝准备对图像进行模糊操作,操作的方法为:

对于每个像素,将以它为中心3×3 区域内的所有像素(可能是 9个像素或少于 9 个像素)求和后除以这个范围内的像素个数(取下整),得到的值就是模糊后的结果。

请注意每个像素都要用原图中的灰度值计算求和。

输入描述

输入的第一行包含两个整数 n,m。

第 2行到第 n+1 行每行包含 m 个整数,表示每个像素的灰度值,相邻整数之间用一个空格分隔。

其中,1≤n,m≤100 。

输出描述

输出 n 行,每行 m 个整数,相邻整数之间用空格分隔,表示模糊后的图像。

输入输出样例

示例 1

输入

复制代码
3 4
0 0 0 255
0 0 255 0
0 30 255 255

输出

复制代码
0 42 85 127
5 60 116 170
7 90 132 191

运行限制

  • 最大运行时间:1s
  • 最大运行内存: 128M

总通过次数: 2356 | 总提交次数: 2436 | 通过率: 96.7%

难度: 困难 标签: 2021, 模拟, 枚举, 模拟赛

cpp 复制代码
#include <iostream>
using namespace std;
int main()
{
  int n,m;
  cin>>n>>m;
  long long int s[n][m]={0},a[n][m]={0};
  //数组的输入
  for(int i=0;i<n;i++){
    for(int j=0;j<m;j++){
      cin>>s[i][j];
      a[i][j]=s[i][j];
    }
  }

  for(int i=0;i<n;i++){
    for(int j=0;j<m;j++){
      int sum=0,l=0;
      //控制九宫格内的数字3*3的大小
      for(int z=-1;z<=1;z++){
        for(int x=-1;x<=1;x++){
          if(i+z<0||i+z>=n||j+x<0||j+x>=m){}
          else{
            sum+=s[i+z][j+x];
            l++;
          }
                  }
      }
      a[i][j]=sum/l;

    }
  }

  for(int i=0;i<n;i++){
    for(int j=0;j<m;j++){
      if(j==0)
      cout<<a[i][j];
      else
      cout<<" "<<a[i][j];
    }
    cout<<endl;
  }
  // 请在此输入您的代码
  return 0;
}
相关推荐
吴声子夜歌7 分钟前
OpenCV——Mat类及常用数据结构
数据结构·opencv·webpack
笑口常开xpr36 分钟前
数 据 结 构 进 阶:哨 兵 位 的 头 结 点 如 何 简 化 链 表 操 作
数据结构·链表·哨兵位的头节点
BUG收容所所长1 小时前
栈的奇妙世界:从冰棒到算法的华丽转身
前端·javascript·算法
愚润求学1 小时前
【C++】类型转换
开发语言·c++
XRZaaa1 小时前
常见排序算法详解与C语言实现
c语言·算法·排序算法
@我漫长的孤独流浪1 小时前
数据结构测试模拟题(4)
数据结构·c++·算法
智驱力人工智能1 小时前
智慧零售管理中的客流统计与属性分析
人工智能·算法·边缘计算·零售·智慧零售·聚众识别·人员计数
csdnzzt2 小时前
从内存角度透视现代C++关键特性
c++
jie188945758662 小时前
C++ 中的 const 知识点详解,c++和c语言区别
java·c语言·c++
明月*清风2 小时前
c++ —— 内存管理
开发语言·c++