0

我在搞乱文件输入/输出,我正在尝试制作一个编码/解码程序。我需要帮助将文件中的编码字符读回要解码的程序。(这不是一个作业,因为我明年才上 9 年级,我正在尝试这样做,因为它看起来很有挑战性。)这是我的代码:

#include <iostream>
#include <fstream>
#include <string>
#include <cstdio>
#include <cstdlib>
/* 
 * OUT: categorize words into char's, assign a symbol/number to each char, output number 
 *      combonation to file.
    IN: load file, decode file, read decoded version. */ 

using namespace std;

void Encode(){
        char message[100];
    char ENCODED[100];
    cout<<"input new content:\n>";
    cin.getline(message, 99);
    cin.ignore();
    cout<<"encoding...\n";
    for (int i=0; i<100; ++i){
             if (message[i]=='a') ENCODED[i]='1';
        else if (message[i]=='b') ENCODED[i]='$';
        else if (message[i]=='c') ENCODED[i]='!';
        else if (message[i]=='d') ENCODED[i]='*';
        else if (message[i]=='e') ENCODED[i]='2';
        else if (message[i]=='f') ENCODED[i]='&';
        else if (message[i]=='g') ENCODED[i]='^';
        else if (message[i]=='h') ENCODED[i]='%';
        else if (message[i]=='i') ENCODED[i]='3';
        else if (message[i]=='j') ENCODED[i]='=';
        else if (message[i]=='k') ENCODED[i]='_';
        else if (message[i]=='l') ENCODED[i]='-';
        else if (message[i]=='m') ENCODED[i]='2';
        else if (message[i]=='n') ENCODED[i]='9';
        else if (message[i]=='o') ENCODED[i]='4';
        else if (message[i]=='p') ENCODED[i]='|';
        else if (message[i]=='q') ENCODED[i]='/';
        else if (message[i]=='r') ENCODED[i]='>';
        else if (message[i]=='s') ENCODED[i]='?';
        else if (message[i]=='t') ENCODED[i]='}';
        else if (message[i]=='u') ENCODED[i]='5';
        else if (message[i]=='v') ENCODED[i]=',';
        else if (message[i]=='w') ENCODED[i]='.';
        else if (message[i]=='x') ENCODED[i]=';';
        else if (message[i]=='y') ENCODED[i]=')';
        else if (message[i]=='z') ENCODED[i]='@';
        else if (message[i]==' ') ENCODED[i]='#';
                else if (message[i] =='\0') {ENCODED[i] = '\}'; break;}
        else ENCODED[i]=' ';
    }
    cout<<"done encoding.\n";
    cout<<"exporting file...\n";
    ofstream OUTfile ("encoded.txt");
    OUTfile<<ENCODED;
    cout<<"file exported to parent directory.\n"; 
    cin.get();
}

void Decode(){ //this is where I run into problems!!
        string encoded[100]
    char DECODED[100]
    ifstream INfile ("encoded.txt");
    cout<<"Decoding...\n";
    INfile>>encoded;
    for (i=0; i<100; ++i){
             if (encoded[i]=='1') DECODED[i]='a';
        else if (encoded[i]=='$') DECODED[i]='b';
        else if (encoded[i]=='!') DECODED[i]='c';
        else if (encoded[i]=='*') DECODED[i]='d';
        else if (encoded[i]=='2') DECODED[i]='e';
        else if (encoded[i]=='&') DECODED[i]='f';
        else if (encoded[i]=='^') DECODED[i]='g';
        else if (encoded[i]=='%') DECODED[i]='h';
        else if (encoded[i]=='3') DECODED[i]='i';
        else if (encoded[i]=='=') DECODED[i]='j';
        else if (encoded[i]=='_') DECODED[i]='k';
        else if (encoded[i]=='-') DECODED[i]='l';
        else if (encoded[i]=='2') DECODED[i]='m';
        else if (encoded[i]=='9') DECODED[i]='n';
        else if (encoded[i]=='4') DECODED[i]='o';
        else if (encoded[i]=='|') DECODED[i]='p';
        else if (encoded[i]=='/') DECODED[i]='q';
        else if (encoded[i]=='>') DECODED[i]='r';
        else if (encoded[i]=='?') DECODED[i]='s';
        else if (encoded[i]=='}') DECODED[i]='t';
        else if (encoded[i]=='5') DECODED[i]='u';
        else if (encoded[i]==',') DECODED[i]='v';
        else if (encoded[i]=='.') DECODED[i]='w';
        else if (encoded[i]==';') DECODED[i]='x';
        else if (encoded[i]==')') DECODED[i]='y';
        else if (encoded[i]=='@') DECODED[i]='z';
        else if (encoded[i]=='#') DECODED[i]=' ';
                else if (encoded[i] =='\0') {DECODED[i] = '\}'; break;}
        else DECODED[i]==' ';
    } 
    cout<<"Decoded file content: "<<DECODED;
    cin.get();
}


int main(){
    string choice;
    cout<<"Encode new message or decode previous file?\n> ";
    cin>>choice;
    cin.ignore();
    if (choice=="encode") Encode();
    if (choice=="decode") Decode();
    return 0;
}

如您所见,当涉及到解码功能时,我不知道自己在做什么。任何帮助,将不胜感激!谢谢!

编辑:我用提供的建议更新了代码,但是当编译器到达“INfile>>encoded;”行时 它说“INfile>>encoded”中的运算符“>>”不匹配......

4

3 回答 3

1

我相信这里的问题是您不了解 char 和 string 之间的区别。char 是一个字母或符号,例如 'a' 'b' 'c' '1' '0' '^' ( 等等。但是一个字符串 - 它是一个字符序列,例如 "abc" "123" "* &^" 等。在 C/C++ 中,我们使用单引号来指定字符,如 'a'。单引号内的值只能包含一个字母。要指定字符串,我们使用双引号,如前所述。A双引号内的值可以包含任意数量的字符。

于 2012-08-01T01:15:04.003 回答
1

问题:

编译失败 (g++-4.5.1) 没有ifstream找到合适的构造函数重载,需要name.c_str().

ifstream INfile (name);

接下来的两个声明中缺少分号

char encoded[100]
char DECODED[100]

循环计数器i未声明 ( for(int i = 0; ...)

for (i=0; i<100; ++i){
         if (encoded[i]=='1') DECODED[i]='a';

从这里开始,您将DECODED[i]与字符常量进行比较,而不是分配它们。将所有这些替换DECODED[i]==DECODED[i] =.

    else if (encoded[i]=='$') DECODED[i]=='b';
    else if (encoded[i]=='!') DECODED[i]=='c';
    else if (encoded[i]=='*') DECODED[i]=='d';

另一个问题是您编码和解码 100 个字符,无论实际消息是否更短。在Decode()Encode()中,添加对字符串结尾的检查

if (array[i] =='\0') {
    other_array[i] = '\}';
    break;
}

结束转换。

于 2012-08-01T01:51:11.910 回答
0

由于这是您自己的练习,我建议您创建一个映射来避免那些疯狂的 if 语句(并让以后更容易修改您的编码):

// Warning: always address these with ints or unsigned char, not char
// if you expect extended ASCII characters
static unsigned char encode_map[256] = {0};
static unsigned char decode_map[256] = {0};

void InitEncodingMap()
{
    encode_map['a'] = '1';
    encode_map['b'] = '$';
    encode_map['c'] = '!';
    encode_map['d'] = '1';
    // etc...
    encode_map['z'] = '@';
    encode_map[' '] = '#';

    // Create the reverse map
    for( int i = 0; i < 256; i++ ) {
        unsigned char encoded = encode_map[i];
        if( decode_map[encoded] != 0 ) {
            printf("Collision for mapping %c -> %c\n", (char)i, encoded );
        } else {
            decode_map[encode_map[i]] = (unsigned char)i;
        }
    }
}

现在,尝试重写您的 Encode 和 Decode 函数以使用这些映射。

于 2012-08-01T01:48:22.040 回答