微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

在C中逐块迭代2D数组

我正在为C中的图像缩小程序做家庭作业.我的图片由2D像素阵列表示;每个像素都是一个成员为“红色”,“绿色”和“蓝色”的对象.为了解决这个问题,我试图一次访问一个块,然后调用一个找到每个块的平均RGB值的函数,并将一个新像素添加一个较小的图像数组中.每个块的大小(或比例因子)由用户输入.

举个例子,想象一下像myArray [10] [10]这样的100项2D数组.如果用户输入缩小系数3,我需要打破3乘3的迷你2D数组.我不必考虑溢出,所以在这个例子中我可以忽略最后一行和最后一列.

我编写了大部分程序,包括查找平均颜色的功能.我对如何遍历2D数组感到困惑.我知道如何顺序循环2D数组(一次一行),但我不知道如何在数组中获得小方块.

任何帮助将不胜感激!

解决方法

像这样的东西应该工作:
for(size_t bx = 0; bx < width;  bx += block_width)
for(size_t by = 0; by < height; by += block_height) {
  float sum = 0;
  for(size_t x = 0; x < block_width; ++x)
  for(size_t y = 0; y < block_height; ++y) {
    sum += array[bx + x][by + y];
  }
  average = sum / (block_width * block_height);
  new_array[bx][by] = average;
}

width是整个宽度,block_width是图中蓝色方块的长度

原文地址:https://www.jb51.cc/c/118641.html

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐