Ich habe die Caesar-Chiffre mit objektorientierter Programmierung implementiert. Das Problem ist, dass wenn ich die verschlüsselte Funktion anrufe, ich die gleiche Nachricht wie die Benutzereingabe bekomme ... Die Nachricht wird nicht richtig verschlüsselt.Caesar-Chiffre objektorientierte Programmierung
Zum Beispiel, wenn ich "abc" statt "bcd" schreibe, bekomme ich "abc". Ich habe es in C++ versucht, der Code funktionierte (die Logik war in Ordnung), aber ich versuchte objektorientiertes Programmieren in C++ und erstellte drei Dateien, um den Code zu trennen.
Kann mir jemand helfen oder einen Fehler identifizieren, den ich gemacht habe?
Executable Test File (main
-Funktion):
#include <iostream>
#include <string>
#include "CyclicShift.h"
using namespace std;
int main()
{
string text;//the string that holds the user input
int key;//key holds the number by which the user wants the alphabets to be shifted
cout << "Enter your phrase: " << endl;
getline(cin, text);//gets the user input (including spaces and saves it to the variable text)
cout << "Please choose a number(key) for which you wants the alphabets to be shifted: " << endl;
/*Note: the key can either be positive (forward shifting), negative (backward shifting) or zero (no shifting)*/
cin >> key;//User input for number by which alphabets are going to be shifted
const CyclicShift aShift;
cout << "Encrypted Message : " << aShift.Encrypt(text, key) << endl;
//system("Pause");
return 0;
}
Header-Datei .h
:
#pragma once
#include <iostream>
#include<string>
//Note: No using "namespace std;" in header files
class CyclicShift
{
private:
char fUpperCase[26];//A-Z
char fLowerCase[26];//a-z
public:
CyclicShift();
std::string& Encrypt(std::string& aOriginalMessage, int &aKey) const;// Function Prototype. This declares Encrypt to be a function that needs one string and one integer variables as arguments. Reference operator & in prototype
};
Quelldatei .cpp
:
#include "CyclicShift.h"
#include<iostream>
#include<string>
using namespace std;
CyclicShift::CyclicShift()
{
char fUpperCase[26] = {'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'};//Initialization of class member
char fLowerCase[26] = {'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'};//Initialization of class member
}
string& CyclicShift::Encrypt(string& aOriginalMessage, int & aKey) const
{
int z;//z holds the value (int) of the length of the user input (including spaces)
z = (int)aOriginalMessage.length(); /*give the variable z the value of the user input length and length is normally an unsigned long integer hence
we have to typecast it*/
/*counter that makes it keep looping until it "encrypts" all of the user input (that's why it keeps looping while its less than z)*/
for (int i = 0; i < z; i++)
{
for (int j = 0; j < 26; j++)
{
if (aOriginalMessage[i] == fLowerCase[j] || aOriginalMessage[i] == fUpperCase[j])
{
if (aKey > 0)
{
//another counter that loops forwards key times by incrementing method
for (int counter = 0; counter < aKey; counter++)
{
/*it checks if the letter text[x] is 'z' and if it is 'z' it will make it 'a'*/
if (aOriginalMessage[i] == 'z')
{
aOriginalMessage[i] = 'a';
}
else if (aOriginalMessage[i] == 'Z')
{
aOriginalMessage[i] = 'A';
}
else
{
aOriginalMessage[i]++;
}
}
}
else if (aKey < 0)
{
//another counter that loops backwards key times by decrementing method
for (int counter = 0; counter < abs(aKey); counter++)
{
/*it checks if the letter text[x] is 'a' and if it is 'a' it will make it 'z'*/
if (aOriginalMessage[i] == 'a')
{
aOriginalMessage[i] = 'z';
}
else if (aOriginalMessage[i] == 'A')
{
aOriginalMessage[i] = 'Z';
}
else
{
aOriginalMessage[i]--;
}
}
}
else
{
aOriginalMessage[i];//No alphabet shifts
}
}
else {
continue;
}
break;
}
}
return aOriginalMessage;
}
Oben sind die drei Code-Dateien von meinem Objekt -orientierte Implementierung: Test ing (main), Header und Quelldatei .cpp.
Thx sowieso aber laut meiner project the fUpperCase und fLowerCase sollten im Konstruktor initialisiert werden und die Vorlage sollte sie wie folgt deklarieren: char fUpperCase [26]; Daher kann ich es nicht statisch machen .... – Ketnav
@Ketnav ok, nur sicher sein, sie nicht im Konstruktor neu zu deklarieren, nur initialisieren sie (nicht mit einer Initialisierungsliste). –
Ich habe sie im Konstruktor neu deklariert :) aber das Ergebnis ist immer noch in Ordnung! – Ketnav