使用递归方法反转ifstream输入

时间:2013-07-22 09:22:13

标签: c++ recursion

我有一个函数int Reverse(ifstream& inFile,int level)。它应该一次读取一个字符,直到达到某个分隔符。然后该函数以相反的顺序显示这些字符。分隔符返回到调用函数。分离器没有逆转。

#include <fstream>
#include <cctype>
#include <iostream>

using namespace std;

inline bool checkSeparator(int someValue)
{
   return(isspace(someValue) || someValue == (int)',' || someValue == (int)':' ||     someValue == (int)';' ||
  someValue == (int)'.' || someValue == (int)'?' || someValue == (int)'!' || someValue == EOF);
}

int Reverse(ifstream &inFile, int level)
{
   int input = inFile.get();

   if (!checkSeparator(input))
      Reverse(inFile, ++level);

   --level;

   if (level == 1)
      input = toupper(input);

   if (!checkSeparator(input))
      cout.put(input);

   if (checkSeparator(input))
      return(input);
}

我到了我无法真正返回分隔符的地步。似乎并非所有控制路径都返回一个值。如何使函数返回正确的值?感谢。

1 个答案:

答案 0 :(得分:2)

如果我弄错了你想要Reverse函数在结尾处返回分隔符。 问题是Reverse函数不一定返回任何内容,因为如果在此递归级别读取的字符不是分隔符,则最后一个if语句不会计算为true。 分隔符不会传播回去。

您可以通过引入另一个变量来解决此问题。

int Reverse(ifstream &inFile, int level)
{
   int input = inFile.get();
   int separator = 0;
   if (checkSeparator(input))
       return input;
   else
       separator = Reverse(inFile, ++level);
   ...
   // remove the last if
   return separator;
}