• Najnowsze pytania
  • Bez odpowiedzi
  • Zadaj pytanie
  • Kategorie
  • Tagi
  • Zdobyte punkty
  • Ekipa ninja
  • IRC
  • FAQ
  • Regulamin
  • Książki warte uwagi

Potrzebuję pomysłu na algorytm sprawdzający wszystkie opcje

Object Storage Arubacloud
0 głosów
257 wizyt
pytanie zadane 16 stycznia 2017 w C i C++ przez zrealowanydawidos Nowicjusz (160 p.)

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;
}

 

 

Zaloguj lub zarejestruj się, aby odpowiedzieć na to pytanie.

Podobne pytania

0 głosów
1 odpowiedź 105 wizyt
pytanie zadane 26 października 2020 w PHP przez vingilot85 Obywatel (1,150 p.)
0 głosów
1 odpowiedź 830 wizyt
0 głosów
2 odpowiedzi 10,448 wizyt
pytanie zadane 19 grudnia 2016 w C i C++ przez niezalogowany

92,555 zapytań

141,403 odpowiedzi

319,557 komentarzy

61,940 pasjonatów

Motyw:

Akcja Pajacyk

Pajacyk od wielu lat dożywia dzieci. Pomóż klikając w zielony brzuszek na stronie. Dziękujemy! ♡

Oto polecana książka warta uwagi.
Pełną listę książek znajdziesz tutaj.

Akademia Sekuraka

Kolejna edycja największej imprezy hakerskiej w Polsce, czyli Mega Sekurak Hacking Party odbędzie się już 20 maja 2024r. Z tej okazji mamy dla Was kod: pasjamshp - jeżeli wpiszecie go w koszyku, to wówczas otrzymacie 40% zniżki na bilet w wersji standard!

Więcej informacji na temat imprezy znajdziecie tutaj. Dziękujemy ekipie Sekuraka za taką fajną zniżkę dla wszystkich Pasjonatów!

Akademia Sekuraka

Niedawno wystartował dodruk tej świetnej, rozchwytywanej książki (około 940 stron). Mamy dla Was kod: pasja (wpiszcie go w koszyku), dzięki któremu otrzymujemy 10% zniżki - dziękujemy zaprzyjaźnionej ekipie Sekuraka za taki bonus dla Pasjonatów! Książka to pierwszy tom z serii o ITsec, który łagodnie wprowadzi w świat bezpieczeństwa IT każdą osobę - warto, polecamy!

...