我有一个3x3矩阵,没有排序。
按升序或降序对3x3矩阵进行排序后,我想将中值存储在整数变量(int med
)中。
由于我的矩阵具有奇数个元素,我知道每次中值都是matrix[1][1]
,所以我基本上写得像这样:
int med = matrix[1][1];
虽然在运行应用程序中位数时我在Visual Studio中没有编译时错误,但我得到了以下运行时错误:
"#2 run time check failure..the stack around variable matrix[][] is corrupted..
以下是代码:
#include "stdafx.h"
#include <math.h>
#include <mtip.h>
#define MAX 3
int medianfilter_MIF(HMTIPMOD hMod ,Dataset_byte *in,Dataset_byte **out,int th)
{
if(!in)
{
mmsg_ReportError("Missing input!");
return MRV_FAILURE;
}
*out = (Dataset_byte*)md_DatasetClone((Dataset*)in, DST_SAME);
if(!*out)
{
mmsg_ReportError("Could not clone image!");
return MRV_FAILURE;
}
BYTE *pin = DATA_PTR(in);
BYTE *pout = DATA_PTR(*out);
int d_w = NX(in);
int d_h = NY(in);
int mask2d_int[MAX][MAX];
int *element;
int temp;
for (int i = 1; i < d_w - 1; i++){
for (int j = 1; j < d_h - 1; j++){
int temp = VAL2(in,i,j);
mmsg_ReportError("the value of temp is: %d ",temp);
for (int p = i - 1; p < i + 2; p++){
for (int q = j - 1; q < j + 2; q++){
mask2d_int[p][q]=VAL2(in,p,q);
mmsg_ReportError("the value of mask2d_int[p][q] : %d ",mask2d_int[p][q]);
}
}
for (element = &mask2d_int[0][0]; element <= &mask2d_int[MAX-1][MAX-1]; element ++) {
if (*element > *(element + 1)) {
*element ^= *(element + 1); /* exclusive or swap */
*(element + 1) ^= *element;
*element ^= *(element + 1);
}
msg_ReportError("the value of element after swapping is %d ",element);
}
int med = mask2d_int[1][1];
mmsg_ReportError("the value of median is: %d ",med);
if ((temp - med) < th){
*pout = temp;
mmsg_ReportError("the value of *pout before is %d ",*pout);
}
else{
*pout = med;
mmsg_ReportError("the value of *pout after is %d ",*pout);
}
++pout;
}
}
return MRV_SUCCESS;
}
int medianfilter_MDF(HMTIPMOD hMod)
{
INPUT_DATASET("Input image", 0, 0, DST_BYTE, CONN_REQUIRED);
OUTPUT_DATASET("Output image", 0, 0, DST_BYTE, 0);
CONTROL_INT_SLIDER("threshold:",30,0,255);
return MRV_SUCCESS;
}
REGISTER_MTIP_MODULE("Median Filter", medianfilter_MDF, medianfilter_MIF, 0, 0, 0);
答案 0 :(得分:1)
看看
for (element = &mask2d_int[0][0]; element <= &mask2d_int[MAX-1][MAX-1]; element ++) {
^^
if (*element > *(element + 1)) {
^^^^^^^^^^^
你循环element <= &mask2d_int[MAX-1][MAX-1]
这意味着元素运行并包括最后一个int,然后你将它与“next”int(不存在)进行比较,并可能交换。
多维数组后面的字节包含一个“魔术值”,由编译器放置(可能是生成调试版本)。在数组之后用字节交换数组中的最后一个int会破坏此值,从而导致您看到的错误。
将for循环更改为
for (element = &mask2d_int[0][0]; element < &mask2d_int[MAX-1][MAX-1]; element ++) {
^
应该这样做。
如果您想要的是让它运转起来 - 那么我就说了 - 但我注意到您对矩阵进行排序的唯一原因是获得中位数,并且您已经标记了这个问题“c ++”意味着如果您有兴趣,有一些更简单的方法可以做到这一点。