【蓝桥杯 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;
}
相关推荐
Tisfy3 分钟前
LeetCode 3453.分割正方形 I:二分查找
算法·leetcode·二分查找·题解·二分
漫随流水3 分钟前
leetcode算法(101.对称二叉树)
数据结构·算法·leetcode·二叉树
王老师青少年编程6 分钟前
2025年12月GESP真题及题解(C++七级): 学习小组
c++·gesp·csp·信奥赛·七级·csp-s·提高组
迷途之人不知返9 分钟前
C++初识(2)
c++
源代码•宸11 分钟前
Golang原理剖析(string面试与分析、slice、slice面试与分析)
后端·算法·面试·golang·扩容·string·slice
派森先生13 分钟前
排序算法-冒泡排序
算法·排序算法
静心问道16 分钟前
排序算法分类及实现
算法·排序算法
澄澈青空~30 分钟前
接续:DKOM 进程隐藏的原理
c++·安全
2301_7644413339 分钟前
python实现罗斯勒吸引子(Rössler Attractor)
开发语言·数据结构·python·算法·信息可视化
码农三叔43 分钟前
(7-3)自动驾驶中的动态环境路径重规划:实战案例:探险家的行进路线
人工智能·算法·机器学习·机器人·自动驾驶