【华为OD机考 统一考试机试】 简单的自动曝光、平均像素值(C++ Java JavaScript Python )

华为OD机考:OD统一考试D卷+C卷+A卷+B卷+刷题OJ

真题目录:华为OD机考机试 真题目录( D卷 +C卷 + B卷 + A卷) + 考点说明
在线OJ:点击立即刷题,模拟真实机考环境
华为OD面试真题精选:华为OD面试真题精选

题目描述

一个图像有n个像素点,存储在一个长度为n的数组img里,每个像素点的取值范围[0,255]的正整数。
请你给图像每个像素点值加上一个整数k(可以是负数),得到新图newImg,使得新图newImg的所有像素平均值最接近中位值128。
请输出这个整数k。

输入描述

n个整数,中间用空格分开

输出描述

一个整数k

备注

• 1 <= n <= 100
• 如有多个整数k都满足,输出小的那个k;
• 新图的像素值会自动截取到[0,255]范围。当新像素值<0,其值会更改为0;当新像素值>255,其值会更改为255;

例如newImg=”-1 -2 256″,会自动更改为”0 0 255″

用例

输入 129 130 129 130
输出 -2
说明 -1的均值128.5,-2的均值为127.5,输出较小的数-2

题目解析

注意边界条件:

  1. 如有多个整数k都满足,输出小的那个k
  2. 当新像素值<0,其值会更改为0;当新像素值>255,其值会更改为255

代码思路

这道题目的思路是枚举每一个可能的k值,计算出新图像的每个像素点的值,然后计算新图像的平均值与中位值128的差的绝对值,最后选出差距最小的k值。

具体实现过程如下:

  1. 读入图像像素点的值,存储在数组img中。

  2. 对于每一个可能的k值,计算出新图像的每个像素点的值&#x

  • 2
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

算法大师

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值