dポイントプレゼントキャンペーン実施中!

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

シーザー暗号を複合化するプログラムを教えてください!

大文字と小文字が混合の文字列で3つずらして複合化したいです

文字数が28字などでは収まらないくらいあります

それをふまえたプログラムを教えてください

よろしくお願いします

A 回答 (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% …

もし、ASCIIコード(英字)がわからなければ、こちらをご覧ください。
http://e-words.jp/p/r-ascii.html
    • good
    • 0

どう「複合」するのでしょうか?


混ぜ合わせるモノが判らなければちょっと答えられません

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

お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!