【蓝桥杯 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;
}
相关推荐
roman_日积跬步-终至千里5 分钟前
【模式识别与机器学习(4)】主要算法与技术(中篇:概率统计与回归方法)之线性回归模型
算法·机器学习
小李小李快乐不已8 分钟前
图论理论基础(2)
java·开发语言·c++·算法·图论
点云SLAM9 分钟前
四元数 (Quaternion)微分-单位四元数 q(t) 的导数详细推导(10)
算法·计算机视觉·机器人·slam·imu·四元数·单位四元数求导
秋邱11 分钟前
2025 年突破性科技:大模型驱动的实时多模态数据流处理系统
人工智能·科技·算法·机器学习
sin_hielo12 分钟前
leetcode 2141
数据结构·算法·leetcode
qq_4335545415 分钟前
C++ 最长单调子序列
c++·算法·图论
明洞日记16 分钟前
【数据结构手册005】树结构入门 - 从二叉树到层次智慧
网络·数据结构·c++
youngee1117 分钟前
hot100-39二叉树层序遍历
数据结构·算法
深蓝电商API17 分钟前
爬虫请求参数签名算法逆向(md5、aes、rsa、sm2 全套)
爬虫·算法·状态模式
未可知77718 分钟前
软件设计师(下午题2)、UML与设计模式
算法·设计模式·职场和发展·uml