这个RLE解码功能只解码第一个字符,我做错了什么?

This RLE decoding function is decoding only the first character, what am I doing wrong?

本文关键字:解码 错了 什么 字符 RLE 功能 第一个 这个      更新时间:2023-10-16

我正在编写一个简单的程序,它使用 RLE 算法压缩字符串,我成功地编写了编码函数,并认为我也已经弄清楚了解码函数,但它没有给出正确的输出。

string RunLengthDecoding(string input)
{
string decodedOutput = "";
int secondIterator = 0;
for(int firstIterator=0; firstIterator<input.length(); firstIterator++)
{
string counter = ""; int letterCoefficient = 0;
if(!isalpha(input[firstIterator]))
continue;
else
{
counter = input.substr(secondIterator, firstIterator);
secondIterator = firstIterator;
istringstream(counter) >> letterCoefficient;
for(int i=0; i<letterCoefficient; i++)
decodedOutput += input[firstIterator];
}
}
return decodedOutput;
}

如果我输入"6A"或任何粘在任何单数字符上的数字,它可以正常工作。 例:

6A -->

AAAAAAA, 77B --> BBBBB.....BBBBB 77次。

但是如果我输入"6A3B",它会吐出"AAAAAA"。或者真的任何卡在 A 旁边的数字和卡在 B 旁边的任何数字,它仍然会真正打印第一个字符的前缀次数,完全忽略它后面的所有内容。

应该更像这样:

string RunLengthDecoding(string input)
{
string decodedOutput = "";
int secondIterator = 0;
for (int firstIterator = 0; firstIterator<input.length(); firstIterator++)
{
string counter = ""; int letterCoefficient = 0;
if (!isalpha(input[firstIterator]))
continue;
else
{
counter = input.substr(secondIterator, firstIterator - secondIterator); // Little change here
secondIterator = firstIterator + 1; // Add one here
istringstream(counter) >> letterCoefficient;
for (int i = 0; i<letterCoefficient; i++)
decodedOutput += input[firstIterator];
}
}
return decodedOutput;
}

请注意,这似乎适用于基本输入,例如"6A3B25C",但我觉得某些边缘情况会打破这一点,因为没有安全检查。