• 締切済み

プログラミング シーザー暗号 複合化 C言語

プログラミング シーザー暗号 複合化 Linux C言語 シーザー暗号を複合化するプログラムを教えてください! 大文字と小文字が混合の文字列で3つずらして複合化したいです 文字数が28字などでは収まらないくらいあります それをふまえたプログラムを教えてください よろしくお願いします

みんなの回答

noname#140082
noname#140082
回答No.2

シーザー暗号はコンピュータがまだ無い時代のもので、非常に単純な暗号と言えます。 しかし、こんな単純なものでも、いざプログラムでやろうとすると、色々なやり方があります。 Wikipediaでシーザー暗号を見ると、必ずしも3つずらすのが決まりではないようです。 ですから、もし汎用性を考えれば、3を変数に代入してNo.1さんのような方法が適切と思いますが、あえて究極のやり方を考えるならば、次のような方法があります。 unsigned char decipher_tbl[256] = "****************" "****************" "****************" "****************" "*xyzABCDEFGHIJKL" "MNOPQRSTUVW*****" "*XYZabcdefghijkl" "mnopqrstuvw*****" "****************" "****************" "****************" "****************" "****************" "****************" "****************" "****************"; plaintext = decipher_tbl[decipher_text]; decipher_textが1文字の暗号文字となります。 1文字の復号ならば、これだけで完成です。 この方式の最大の利点は、このテーブルが正しければ、絶対に間違いがないこと。 つまり、動作確認テストが楽なことです。 そして、たとえば数字も変換することにした場合も、このテーブルを仕様に合わせて変更するだけで済みます。 (もし、外部ファイルにすれば、リコンパイルの必要さえ無くなります) そして、今は面倒なので対象文字(つまり英字)以外は"*"にしましたが、対象文字以外をそのまま出力するか、あるいはすべてを3つずらすかなども、このテーブルを変更すれば自由自在です。 但し、対象文字以外は削除するなど(暗号化時に)文字を減らしたりする場合には、暗号化前にそれなりのロジックが必要となります。 また、最初に記述したようにずらすのは、3(でなくともいいのですが)の固定となります。 そして、この方法がシーザー暗号の最速の方法です。 http://ja.wikipedia.org/wiki/%E3%82%B7%E3%83%BC%E3%82%B6%E3%83%BC%E6%9A%97%E5%8F%B7 もし、ASCIIコード(英字)がわからなければ、こちらをご覧ください。 http://e-words.jp/p/r-ascii.html

回答No.1

どう「複合」するのでしょうか? 混ぜ合わせるモノが判らなければちょっと答えられません と云うネタはこのあたりにしておいて「復号」するのですよね ・まず元の文字列をchar配列にでもする ・文字コード的には単純に数を引いたり足したりすれば出たりする   例えば「char c = 'z' - 3」という計算をすれば'w'が得られるはずです   但し'a' - 3 など、範囲外となる場合にはそれなりの対応をする必要があります

関連するQ&A