【发布时间】:2012-03-13 20:02:46
【问题描述】:
更新:如果有人正在阅读本文并遇到类似问题,那么问题似乎在于我将双精度转换为整数。例如,我认为 54 存储为 54.000...,它实际上存储为 53.99999...,当更改为 int 时,它变成了 53。 我发现解决这个问题的方法是简单地添加 0.5 和代码
int output_buffer=O[m][n];
变成
int output_buffer=O[m][n]+0.5;
我有一个名为“O”的二维双精度数组。在哪里
double O[3][3];
我以这个确切的顺序依次使用这两个函数;
...
displaymatrixO();
writedecrypted();
...
在哪里
int displaymatrixO()
{ cout << "O is:" << "\n";
for (int n=0;n<3;n++)
for (int m=0;m<3;m++)
{
cout << O[m][n];
if (m == 2) cout << "\n";
else cout << " ";
}
}
还有
int writedecrypted()
{ for (int n=0;n<3;n++)
for (int m=0;m<3;m++)
{
int output_buffer=O[m][n];
fputc (output_buffer,opFile);
}
}
在哪里
FILE *opFile;
opFile=fopen ("decrypted.txt","wb");
...
程序运行时,第一个函数(displaymatrixO)以这种方式将矩阵O输出到屏幕:
O is:
49 50 51
52 53 54
3 3 3
这是正确的,这就是 O 应该是的。
然后,第二个函数应该对矩阵的各个值进行类型转换并将其写入一个文件,其中每个值占用 8 位/ 1 个字节的空间。当我使用十六进制编辑器查看文件时,文件是这样的(十六进制):
0x31 0x32 0x33 0x33 0x35 0x35 0x03 0x03 0x03
在 8 位有符号整数格式中(即如何使用 displaymatrixO 显示 O),如下所示:
49 50 51 51 53 53 3 3 3
即
49 50 51
51 53 53
3 3 3
似乎将 O[2][0] 复制到 O[0][1] 并将 O[1][1] 复制到 O[2][1]。我一遍又一遍地查看代码,我似乎无法弄清楚我哪里出错了!如果可以,请提供帮助...
【问题讨论】:
-
你可以尝试初始化 int output_buffer=O[m][n];首先使用 int output_buffer = 0?这是我在您的代码中临时看到的唯一可能是内存被重用的地方。
-
欢迎来到 StackOverflow!您发布的代码没有任何问题(如this program 所示)。问题一定出在您没有发布的代码中。请发布尽可能短的完整程序来演示您所看到的错误。 (有关此调试技术的更多信息,请参阅sscce.org)。
-
而且,仅供参考:Rob 所描述的内容称为“测试用例”。
-
其实整个代码还有一个问题,好像写了两次同一个矩阵,但是我还是把代码贴出来,用一个缩短的形式(并删除不存在于最短形式的函数主要的)。它不编译(上传站点),因为我假设该站点没有 MATLAB。无论如何,这里是:ideone.com/jtkK7
-
这里是输入和输出文件(加密和解密的.txt); ideone.com/xy1mL
标签: c++ arrays file casting writing