我的解码程序的两个部分无法正常工作

时间:2019-10-12 01:17:20

标签: c++

几天前,我来到这里寻求帮助(有更具体的部分),但是我得到的解决方案却行不通。基本上,我正在写一个用于3个目的的程序:解码Rot 13密码,解码Rot 6密码,并通过等式“ x = 2n-1”放置用户输入,其中n是用户输入。

第13轮工作正常,但第6轮输出乱码,等式输出一个字母(输入“ 8”表示o而不是15)

我知道可以用更少的功能来完成此操作,并且我可能不需要列表,但这是用于分配的,我需要它们

我知道我并不擅长此事,但是任何帮助都会很棒

#include <iostream>
#include <string>
#include <list>
#include <array>
using namespace std;
string coffeeCode(string input) {   //Coffee code= 2n-1 where n=a number in a string
    double index{};
    input[index] = 2*input[index]-1;


    return input;
};

string rot6(string input) {
    int lower[] = { 'a','b','c','d','e','f','g','h','i','j','k','l','m','n','o','p','q','r','s','t','u','v','w','x','y','z',' ' };
    int upper[] = { 'A','B','C','D','E','F','G','H','I','J','K','L','M','N','O','P','Q','R','S','T','U','V','W','X','Y','Z' };
    int inputSize = input.size();  // rot 6 rotates letters so that a{0}->g[6]
    int index{};      //         m[12]->s[18]
    //         n->t
    while (index != inputSize) {  //         z->f
        if (input[index] >= lower[0] && input[index] <= lower[19])
            input[index] = input[index] + 6;
        else if (input[index] >= lower[20] && input[index] <= lower[25])
            input[index] = input[index] - 20;
        else if (input[index] >= upper[0] && input[index] <= upper[19])
            input[index] = input[index] + 6;
        else if (input[index] <= upper[20] && input[index] <= upper[25])
            input[index] = input[index] - 20;

        index++;
    }
    return input;
}
string rot13(string input) {  //Decodes into rot 13
    int lower[] = { 'a','b','c','d','e','f','g','h','i','j','k','l','m','n','o','p','q','r','s','t','u','v','w','x','y','z',' ' };
    int upper[] = { 'A','B','C','D','E','F','G','H','I','J','K','L','M','N','O','P','Q','R','S','T','U','V','W','X','Y','Z' };
    int inputSize = input.size();
    int index{};
    while (index != inputSize) {
        if (input[index] >= lower[0] && input[index] <= lower[12])
            input[index] = input[index] + 13;
        else if (input[index] >= lower[13] && input[index] <= lower[25])
            input[index] = input[index] - 13;
        else if (input[index] >= upper[0] && input[index] <= upper[12])
            input[index] = input[index] + 13;
        else if (input[index] <= upper[13] && input[index] <= upper[25])
            input[index] = input[index] - 13;


        index++;
    }
    return input;
}
int main() {
    string plaintext;
    string ans13;
    string ans6;
    string ansCoffee;
    cout << "Whats the message Spy Guy: ";
    getline(cin, plaintext);
    ans13 = rot13(plaintext);
    ans6 = rot6(plaintext);
    ansCoffee = coffeeCode(plaintext);
    cout << "One of these is your decoded message" << endl << "In Rot 13:  " << ans13 << endl << "In Rot 6:  " << ans6 << endl
         << "In Coffee Code:  " << ansCoffee << endl;
    return 0;
}

1 个答案:

答案 0 :(得分:0)

了解您正在做什么的最好机会是阅读有关c ++如何处理字符以及什么是ASCII的信息。

[http://www.asciitable.com/]

快速摘要:

ASCII表为英文字母中的每个字符分配一个数字(或代码),而该数字就是C ++实际存储在内存中的数字。 因此,当您执行char c = 'a'时等同于执行char c = 97

ASCII表也非常有条理,因此所有大写字母均按字母顺序从65(即A)到90(即Z)开始。非大写字母从97到122,数字从48到57也是如此。 可以用来确定变量是哪种字符:

if ('a' <= input[index] && input[index] <= 'z') {
    // It's lower case
}
if('A' <= input[index] && input[index] <= 'Z') {
    // It's upper case
}

请注意,当您在单引号中添加一个单字符时,编译器将使用ASCII码替换该字符,因此您实际上不需要记住该表。考虑一下如何构造一个if来确定字符是否为数字。

这是我实现rot6的方法。可能不是最好的选择,但我认为还可以。

string rot6(string input) {
    for (int index = 0; index < input.size(); ++ index) {
        if ('a' <= input[index] && input[index] <= 'z') { // It's lower case
            input[index] = 'a' + ((input[index] - 'a') + 6) % 26;
        }
        else if ('A' <= input[index] && input[index] <= 'Z') { // It's upper case
            input[index] = 'A' + ((input[index] - 'A') + 6) % 26;
        }
        else if ('0' <= input[index] && input[index] <= '9') { // It's a digit
            input[index] = '0' + ((input[index] - '0') + 6) % 10;
        }
        else { // It's an error
            return "Error, bad input!";
        }
    }
    return input;
}