Witam, mam do zrobienia projekt w asm do uczelnie, ale to nie jest tu istotne.
Teraz chcę zrobić implementację tego w c++ a dopiero potem zajmę się przepisanie na asm.
Temat projektu to deszyfrowanie ADFGVX LINK-WIKIPEDIA.
Moje założenia do tego tematu są następujące:
1. Wypełnić tablice dwuwymiarową [6][6] kolejnymi znakami ascii a->z + 0->9, będzie to moja baza od odszyfrowywania.
2. Muszę przestawiać kolumny uzyskać kolejne opcje możliwości ustawienia. Dzięki czemu będę miał różne tłumaczenia zaszyfrowanych fraz.
3. Ustalono, że znam pierwszy wyraz do przetłumaczenia - "hitler" - dużych liter tu nie używamy.
Sprawdzanie kolejnych kombinacji kończy się gdy nasze ustawienie kolumn daje nam właśnie odczyt z zaszyfrowanego "hitler" odszyfrowanego hitlera.
Wtedy wykonuje odszyfrowanie dla pozostałego tekstu, gdyż już znam ustawienie kolumn.
Coś zacząłem, nie wiem czy mądrze, jeśli ktoś mógłby nasunąć mi pomysł, i wytłumaczył mi go dość przystępnie byłbym wdzięczny, nie chce żeby mi ktoś pisał kod.
Problem odnosi się do algorytmu które będzie sprawdzał kolejne możliwości ustawienia.
#include <iostream>
using namespace std;
char tablica [6][6];
char x = 'a';
char tmp [6];
char static tab[6][6];
void wypelnij(){
for(int i=0; i<6 ; i++){
for(int j=0 ; j<6 ; j++){
tablica [i][j]=x;
if(x=='z'){
x='/';
}
x++;
}
}
for(int i=0; i<6 ; i++){
for(int j=0 ; j<6 ; j++){
tab[i][j]=tablica[i][j];
}
}
}
void wypisz (){
for(int i=0; i<6 ; i++){
for(int j=0 ; j<6 ; j++){
cout<<tablica[i][j];
}
cout<<endl;
}
}
void zamiana (int x, int y){
for(int i=0 ; i<6 ; i++){
tmp[i]=tablica[i][x];
tablica[i][x]=tablica[i][y];
tablica[i][y]=tmp[i];
}
}
int main(int argc, char** argv) {
wypelnij();
wypisz();
zamiana(0,1);
cout<<endl;
wypisz();
return 0;
}