PGPってすごく良いの?
レス数が900を超えています。1000を超えると表示できなくなるよ。
0001おぺけぺ
NGNGそんなに良い物なの?
絶対に破られない暗号化ソフトだから、CIAも使ってるって言ってたけど、
それって本当?
胡散臭
0839向こうから ◆tr.t4dJfuU
NGNGちょっと このへんで 無理そうです・・・
0840名無しさん@お腹いっぱい。
NGNG0841合同式
NGNG0842向こうから ◆tr.t4dJfuU
NGNG9^47 が計算できんかったら むりじゃないかと・・
VBAでどうしろと?
アルゴリズム か フロー で 示してくれたら できるかも・・
でも まぁ このへんで
ありがとございました
0843向こうから ◆tr.t4dJfuU
NGNGムズイです・・
0844名無しさん@お腹いっぱい。
NGNGFOR I=1 TO 47
A=(A*9)MOD 47
NEXT
PRINT A
0845844訂正
NGNGFOR I=1 TO 47
A=(A*9)MOD 21
NEXT
PRINT A
0846名無しさん@お腹いっぱい。
NGNGint my_func(int a,int b,int c);
int my_func(a,b,c)
{
int r;
int i;
r=1;
for(i=0;i<b;i++)
{
r=(r*a)%c;
}
return r;
}
int main(void)
{
int a;
a=my_func(9,47,21);
printf("%d\n",a);
return 0;
}
0847向こうから ◆tr.t4dJfuU
NGNGCは使えないので
VBAでやってみます!
明日から仕事なんで、近日中に・・・
0848向こうから ◆tr.t4dJfuU
NGNGPublic Function ABEKIBMODC(入力A, 入力B, 入力C) As Variant
Debug.Print "開始ーーーーーーー"
Dim A, B, C
Dim I, X, Y
A = 入力A: B = 入力B: C = 入力C
X = 1
For I = 1 To B
X = X + (X * A) Mod C
Debug.Print I, X
Next I
Debug.Print "余り=", X
Y = Hex$(X)
Debug.Print "16進表記", Y
ABEKIBMODC = X
End Function
0849向こうから ◆tr.t4dJfuU
NGNG開始ーーーーーーー
1 10
2 16
3 34
4 46
5 61
6 64
7 73
8 79
省略
45 475
46 487
47 502
余り= 502
16進表記 1F6
00 00 00 00 00 01 F6
と解して、
アスキーコードにすれば いいのかな?
ちょっと 出かけてくるので また よる
0850向こうから ◆tr.t4dJfuU
NGNGちなみに
3行目は 勝手に
A=A+(・・・・・
と 解釈したんですが?????
0851名無しさん@お腹いっぱい。
NGNG× X = X + (X * A) Mod C
○ X = (X * A) Mod C
○ X = MOD( X * A , C )
0852名無しさん@お腹いっぱい。
NGNG$a=9 ;
$b=47 ;
$c=21 ;
$t=1 ;
for ( $i = 0 ; $i < $b ; $i++ ) {
$t=($t * $a) % $c;
};
print "$t\n";
0853名無しさん@お腹いっぱい。
NGNGint aaaa(int a,int x,int p);
int aaaa(int a,int x,int p) {
auto int r;
if(0!=x) {
if((x%2)!=0) {
r=(a*aaaa((a*a)%p,(x-1)/2,p))%p;
}
else {
r=(aaaa((a*a)%p,x/2,p))%p;
}
}
else {
r=1;
}
return r;
}
int main(void) {
auto int a,x,p ,r;
a=9;
x=47;
p=21;
if((x<0)||(p<1)) exit(2);
r=aaaa(a,x,p);
printf("%d\n",r);
return 0;
}
0854向こうから ◆tr.t4dJfuU
NGNGとりあえず 直しました
Public Function ABEKIBMODC(入力A, 入力B, 入力C) As Variant
Debug.Print "開始ーーーーーーー"
Dim A, B, C
Dim I, X, Y
A = 入力A: B = 入力B: C = 入力C
X = 1
For I = 1 To B
X = (X * A) Mod C
Debug.Print I, X
Next I
Debug.Print "余り=", X
Y = Hex$(X)
Debug.Print "16進表記", Y
ABEKIBMODC = X
End Function
0855向こうから ◆tr.t4dJfuU
NGNG開始ーーーーーーー
1 9
2 18
3 15
4 9
5 18
略
44 18
45 15
46 9
47 18
余り= 18
16進表記 12
当たり前ですが、47回目の演算の余りを 答えとしているので、ループさせた意味が
分からないのですが?
これだけじゃ だめなのかな?
0856向こうから ◆tr.t4dJfuU
NGNGB=47
c=21
が 代入されてます
=ABEKIBMODC(9,47,21)
こんな関数になってます。
0857向こうから ◆tr.t4dJfuU
NGNGこれが ヒントなのか・・・・
0858向こうから ◆tr.t4dJfuU
NGNGうーん・・・
わかりません
たとえば
if((x<0)||(p<1)) exit(2);
は、
IF X<0 OR P<1 THEN return
か
IF X<0 AND P<1 THEN return
なのかも、はたまた もっと違うのかも わかりません
BASIC風だと わかるのですが・・・
0859向こうから ◆tr.t4dJfuU
NGNGint aaaa(int a,int x,int p);
ここらへんは・・・
ユーザー定義型
Type ステートメントを使って、異なるデータ型を組み合わせた独自のデータ型を作成できます。ユーザー定義型には 1 つまたは複数のデータ型の要素、配列、または事前に定義したユーザー定義型を格納することができます。次に例を示します。
Type aaaa
a As As Integer ' 整数型変数
x As As Integer ' 整数型変数
p As As Integer ' 整数型変数
End Type
なのか??? わかりません。。。
0860名無しさん@お腹いっぱい。
NGNGp は自然数
( a + b ) mod p == ( ( a mod p ) + ( b mod p ) ) mod p
( a * b ) mod p == ( ( a mod p ) * ( b mod p ) ) mod p
a mod p == ( a + b*p ) mod p
0861名無しさん@お腹いっぱい。
NGNGVersion: 6.5.8ckt
qANQR1DBjgPWp+EIWSWCcxAB/3tw9qlJERkDAJgmOUogIBPhU8aM1AR7Ifb9Ne7V
zK0BjnP/PzcMpQLS16nLmQBu7m3HCWfgndGcgUej9sUA16AB/0Ai5snlu3UuEgtU
wIEvEgmMseCLrfu4OEogWWX8cG3+IxnReQarW0sGihUV0TBs/ulkRtbZvpb5HbIc
3i7oK+3Jc9OlkW4kVm/yAWx4VzFzr6lQp1R7tpyTQMM9NZev6A+tMaiw6EnoVKfI
ZWsFbvv9SSdqpMxN/Uoq8r2ChmmBAtz9x8jVeahZeQf6Nq5Gz/CBh3m3hyS4Z7Ks
heLrmU1qhmxOkAOk9Yfd+9ldDd2c9MKLYQI=
=mSQu
-----END PGP MESSAGE-----
0862向こうから ◆tr.t4dJfuU
NGNG書き換えると
(9^47) MOD 21 で・・・
これ「( a * b ) mod p == ( ( a mod p ) * ( b mod p ) ) mod p 」にあてはめると
(9*47)mod21 = ((9 mod 21)*(47 mod 21)) mod 21 で・・・
関数表現では =mod(mod(9,21)*mod(47,21),21) かな・・
とりあえずエクセルに入れたら、「3」がでました・・
で・・ いいのかな・・
16進でも 3は 3で
00 00 00 00 00 00 00 03
のなか?
でも ASCIIコードに 00 も 03 も 文字は 割り当てられてないです・・
それに
これと>( a + b ) mod p == ( ( a mod p ) + ( b mod p ) ) mod p
これ>a mod p == ( a + b*p ) mod p
を使ってないので
まだまだ だめなんでしょうか・・・
0863向こうから ◆tr.t4dJfuU
NGNG暗号で 話してるんですか?
0864名無しさん@お腹いっぱい。
NGNGa^1 == a
a^2 == a*a
a^3 == a*a*a
a^4 == a*a*a*a
a^5 == a*a*a*a*a
a^n == (a^(n-1))*a
a^(n+1) == (a^n)*a
2^2 == 4
10^3 == 1000
9^2 == 81
0865向こうから ◆tr.t4dJfuU
NGNG9^47=(9^(47-1))*9
はい
わかります
その次も
9^48=(9^47)*9
はい・・ で・・・
あ〜
なんか 頭わるいみたい
こんなのもOKですか?
9^47=(9^10)*(9^10)*(9^10)*(9^10)*(9^7)
でも・・・ 意味ないか・・・
0866向こうから ◆tr.t4dJfuU
NGNGで計算できたけど・・・
=MOD((((9^10)*(9^10)*(9^10)*(9^10)*(9^7))),21)
こーすると エラーだし・・・
0867名無しさん@お腹いっぱい。
NGNG== ( ( ( 9 ^ 46 ) mod 21 ) * 9 ) mod 21
== ( ( ( ( ( 9 ^ 45 ) mod 21 ) * 9 ) mod 21 ) * 9 ) mod 21
== ( ( ( ( ( ( ( 9 ^ 44 ) mod 21 ) * 9 ) mod 21 ) * 9 ) mod 21 ) * 9 ) mod 21
中略
== 18
0868向こうから ◆tr.t4dJfuU
NGNGあまりを 積算した 502 から
502 mod 21 = 19
19は 16進で 13
でも &H13でも 文字はないなぁ・・
0869名無しさん@お腹いっぱい。
NGNG( 9^3 ) mod 21
== ( (9^2) * 9 ) mod 21
== ( ( ( 9^2 ) mod 21 ) * ( 9 mod 21 ) ) mod 21
== ( 18 * 9 ) mod 21
== 15
( 9^4 ) mod 21
== ( (9^3) * 9 ) mod 21
== ( ( ( 9^3 ) mod 21 ) * ( 9 mod 21 ) ) mod 21
== ( 15 * 9 ) mod 21
== 9
( 9^5 ) mod 21
== ( (9^4) * 9 ) mod 21
== ( ( ( 9^4 ) mod 21 ) * ( 9 mod 21 ) ) mod 21
== ( 9 * 9 ) mod 21
== 18
以下同様に ( 9^47 ) mod 21 まで続ける。
0870向こうから ◆tr.t4dJfuU
NGNG一番したは、
(((・・・(((9^1)mod21)*9)mod21)*9)・・・・mod21)*9)
になってるはずだから・・・
X=(9^1)mod21
for I=1 to 47-1
X=X*(Xmod21)*9)
ありゃ・・
(9^1)mod21 に mod21)*9) を 47(か46) 回 掛け合わせるればいいと・・
ここに再帰が 使われる? のか・・・ な・・
いや・・ これでいいのかな?
ちょっと 実験してきます・・・
0871向こうから ◆tr.t4dJfuU
NGNG== ( ( ( 9^46 ) mod 21 ) * ( 9 mod 21 ) ) mod 21
で ↑
ここの(9^46)で オーバーフローする
だめだ・・・
再帰を つかうのか????
こんがらかって どうどうめぐり
0872向こうから ◆tr.t4dJfuU
NGNG(9^1)mod21 に
* 9 ) mod 21
を
47回 掛けるのか・・
X=(9^1)mod21
DIM Y
for I=1 to 47
Y=X*9
X=Y mod 21
next
かな・・
0873向こうから ◆tr.t4dJfuU
NGNGDim I, X, Y
A = 入力A: B = 入力B: C = 入力C
'A=9 B=47 C=21
Y = 0
X = A ^ 1 Mod C
Y = X
For I = 1 To B
Y = Y * 9
X = Y Mod C
Debug.Print I, X
Next I
Debug.Print "余り=", X
ABEKIBMODC = X
End Function
0874向こうから ◆tr.t4dJfuU
NGNG開始ーーーーーーー
1 18
2 15
3 9
4 18
5 15
6 9
7 18
8 15
ここで エラー
>>869 の 答えと 一致(偶然かも)
でも 9回目の ループ で 止まった・・・
なんで
0875向こうから ◆tr.t4dJfuU
NGNGI Y X = 1 81 18
I Y X = 2 729 15
I Y X = 3 6561 9
I Y X = 4 59049 18
I Y X = 5 531441 15
I Y X = 6 4782969 9
I Y X = 7 43046721 18
I Y X = 8 387420489 15
原因
Yの値が オーバーフロー
馬鹿です 自分
やっぱ 再帰 かな・・
わからん
0876向こうから ◆tr.t4dJfuU
NGNG218
315
49
518
略
439
4418
4515
469
4718 <<<<
余りは 規則的に繰り返す
でも ・・・
プログラムで やったわけじゃない
エクセルで縦に並べた
0877名無しさん@お腹いっぱい。
NGNGHash: SHA1
合同式については
数学入門下 岩波新書青版 396
遠山啓 (著)
http://www.amazon.co.jp/exec/obidos/ASIN/4004160057/ref%3Dlm%5Flb%5F14/250-0526484-8392254
VIII 数の魔術と科学
が参考になるかも。
-----BEGIN PGP SIGNATURE-----
Version: GnuPG v1.2.1 (GNU/Linux)
iD8DBQE+iE/+APsqAp/UiEgRAjCDAKCbcAMrdCgeeFsPZEWJ5CB3yvIrpgCdFN90
rWTvP1VNhrmrWT3PZOnq95o=
=t6Po
-----END PGP SIGNATURE-----
0878向こうから ◆tr.t4dJfuU
NGNG2-18
3-15
4-9
43-9
44-18
45-15
46-9
47-18
0879向こうから ◆tr.t4dJfuU
NGNGありがとう ございました
18でも 文字コードないですよな・・・
0880向こうから ◆tr.t4dJfuU
NGNGこれは 漏れに対しての メッセージですか?
ありがとう
ございます
0881名無しさん@お腹いっぱい。
NGNG× X = A ^ 1 Mod C
○ X = A ^ 0 Mod C
× Y = Y * 9
○ Y = X * 9
0882向こうから ◆tr.t4dJfuU
NGNGPublic Function ABEKIBMODC(入力A, 入力B, 入力C) As Variant
Debug.Print "開始ーーーーーーー"
Dim A, B, C
Dim I, X, Y
A = 入力A: B = 入力B: C = 入力C
'A=9 B=47 C=21
Y = 0
X = A ^ 0 Mod C
Y = X
For I = 1 To B
Y = X * 9
X = Y Mod C
Debug.Print "I Y X ="; I, Y, X
Next I
Debug.Print "余り=", X
ABEKIBMODC = X
End Function
0883向こうから ◆tr.t4dJfuU
NGNGI Y X = 1 9 9
I Y X = 2 81 18
I Y X = 3 162 15
I Y X = 4 135 9
I Y X = 5 81 18
略
I Y X = 43 135 9
I Y X = 44 81 18
I Y X = 45 162 15
I Y X = 46 135 9
I Y X = 47 81 18
余り= 18
でました!!!!!!!!!!!!!!!!!!!!!!!!!!!!
0884名無しさん@お腹いっぱい。
NGNGHash: SHA1
ところで
向こうって何処?
-----BEGIN PGP SIGNATURE-----
Version: GnuPG v1.2.1 (GNU/Linux)
iD8DBQE+iFVgAPsqAp/UiEgRAgzAAKDmiCW/qNlnG6vqd4EM9vfi/zgegQCfcH0m
GXgaE1WoFQeb1hoGp7vUBhQ=
=yPwa
-----END PGP SIGNATURE-----
0885向こうから ◆tr.t4dJfuU
NGNG人じゃ ないんですか?
他のスレでPGPって暗号が 簡単に 使えると 紹介が あって、
漏れが興味を持ったのですが・・
そのほかのスレでは、スレチガイ! の お叱りが あって
暗号解読の続きを ここで やってたんです
0886向こうから ◆tr.t4dJfuU
NGNG0887名無しさん@お腹いっぱい。
NGNGこれを応用してeとnとdの値を大きくすると
伝えたい数字=mを大きくする事が出来るのです
n=210682641866528392339924267919521486832254575626011849551005435185793837676391
952488587737546451362177622385218482600517540050364571844864529848980677135592
71048127665947018785888345270242137737997411
e=5
dは秘密鍵だから公開しては駄目
0888名無しさん@お腹いっぱい。
NGNGc=Mod(m^e,n)を出して
c=698554217608521722285159656025858094842043344042897409638522493078199478097402
453624389362145671555027608884321004068910953767391333601595127856237419999890
2499
=
7f32d8993f8fdbeeddf283513ebc3cf6c163b804690a7ca90387970f8d4cdbcfb66bec39dc37f
25b1f8c92a20edebe3e3df0d5dbdb20d52231535af0c2e25efbf70e3
を送る
0889向こうから ◆tr.t4dJfuU
NGNG来てくれたんですね ありがとです
でも・・
そんな 桁 エクセルでは 無理 ですね・・・
でも ありがとう ございました
m^eをnで割った余りをcとし、このスレで晒す
mが1234
として
1234^5 mod 2106・・・・・7411
もう 1234^5で フローします
それに、nの100桁とか 入らない。。
でも 頭の体操になりました
0890名無しさん@お腹いっぱい。
NGNGm'=Mod(c^d,n)
=93076495688256089536609610280499
=496ca60b7bb3f3690289336ae33
を出して
(下位)8バイトを文字列に直して
キーを受け取る
0891名無しさん@お腹いっぱい。
NGNGどうにかして桁を増やす方法ないかな?
上の方の応用で出来ると思う
0892名無しさん@お腹いっぱい。
NGNGPGP使えば?
0893向こうから ◆tr.t4dJfuU
NGNG応用できる 頭は ありません
もしかしたら 10文字くらいの ミニPGPくらいなら できるかも(w
>PGP使えば?
暗号がやりたいんではなく
暗号の作成と解読の仕組みに興味を 持ったので・・
自分で(手計算かVBA)やってみたかったのです。
0894向こうから ◆tr.t4dJfuU
NGNGメシもくわずやってたので 疲れました(w
0895名無しさん@お腹いっぱい。
NGNG小さめのnとeとdを作ってnとeを晒してみて
0896名無しさん@お腹いっぱい。
NGNG乙
0897向こうから ◆tr.t4dJfuU
NGNGでは、近日中にやります
明日 仕事なもんで・・
こんど晒しておきますから また 遊んでください
0898bloom
NGNG0899名無しさん@お腹いっぱい。
NGNG乙〜
pとqがバレるとnとeから誰でもdが出せてしまう
pとqを見つけるにはnを因数分解するしかない
nを大きくしなきゃいけない理由は
容易に因数分解出来てしまうから
0900名無しさん@お腹いっぱい。
NGNGVersion: GnuPG v1.2.1 (GNU/Linux)
jA0EAgMBudCOxORtJM9gpCTQF9tuStvI2eyRIC5AhZJk1QWDqlT1e0uPFODI77C+
wmNVw7k=
=0/gF
-----END PGP MESSAGE-----
0901名無しさん@お腹いっぱい。
NGNGHash: SHA1
\ │ /
/ ̄\ / ̄ ̄ ̄ ̄ ̄ ̄ ̄ ̄ ̄
─( ゚ ∀ ゚ )< PGPPGP!
\_/ \_________
/ │ \
∩ ∧ ∧ / ̄ ̄ ̄ ̄ ̄ ̄ ̄ ̄ ̄ ̄
 ̄ ̄ ̄ ̄ ̄ ̄ ̄ ̄\∩ ∧ ∧ \( ゚∀゚)< PGPPGP!
PGP〜〜〜〜! >( ゚∀゚ )/ | / \__________
________/ | 〈 | |
/ /\_」 / /\」
 ̄ / /
 ̄
-----BEGIN PGP SIGNATURE-----
Version: GnuPG v1.2.1 (GNU/Linux)
iEYEARECAAYFAj6JgzoACgkQAPsqAp/UiEiLcACgk/FWFcu3CCoAyD/HmjY71lPB
iP4AoKCZUW6fT/iDlpq+lA/t7Qkk7iuI
=VJR4
-----END PGP SIGNATURE-----
0902向こうから ◆tr.t4dJfuU
NGNGP=17
q=23
として、
n=p*q=17*23=391
s=(p−1)*(q−1)=16*22=352
で・・
>1 大きな素数(100桁くらい)を2つ作りp,qとする
>2 n=p*qとし、s=(p-1)(q-1)と互いに素(公約数が無い)なeを決める
この eを決めるところが、文章から理解できません。
0903名無しさん@お腹いっぱい。
NGNG352を2で割ってみると割り切れてしまう→×
352を3で割ってみると割り切れない→e=3
こうやってeを決めます
0904向こうから ◆tr.t4dJfuU
NGNGeは、尚且つ 素数で、
任意の数で いいんですね。
順番に2、3、5、7 ・・・
と 割っていって、割れなかった一番初めの素数である 必要はないですね?
では e=109
109は素数 で、352を割れない
0905名無しさん@お腹いっぱい。
NGNGオッケーです
でも
c=Mod(m^e,n)を出す時にeが小さい方が都合がいいですよね
そのかわりdが大きくなってしまうわけですが
0906向こうから ◆tr.t4dJfuU
NGNGもうちょっと検討します・・
なにかというと、
eが小さい方がいいのですが・・・
d*109 が 352 の倍数+1 に なるところの 計算が 浮かばない
なんか ヒントいただけると うれしい
ちなみに素数を吐き出す 関数を作ってました
0907向こうから ◆tr.t4dJfuU
NGNGDebug.Print "素数の検索 開始ーーーーーーーーーーーーーー"
'欲しい個数分の素数を検索する
Dim 素数格納配列上限
Dim 素数配列()
素数格納配列上限 = 欲しい個数
Debug.Print "素数格納配列上限", 素数格納配列上限
ReDim 素数配列(素数格納配列上限)
素数配列(1) = 2 '素数の2は入れておく
素数配列(2) = 3 '素数3も入れておく
Dim 今の個数, 検索対象, 判定, i, j, k
今の個数 = 2
0908向こうから ◆tr.t4dJfuU
NGNG検索対象 = 5 '5から検索開始
For 検索対象 = 5 To 999999999 Step 2
判定 = "素数です"
For j = 3 To 検索対象 - 1
If 検索対象 Mod j = 0 Then
'割れたら素数ではない
判定 = "ダメ"
Exit For
End If
Debug.Print 検索対象; "/"; j; 判定
Next j
If 判定 = "素数です" Then
今の個数 = 今の個数 + 1
素数配列(今の個数) = 検索対象
If 今の個数 = 素数格納配列上限 Then
Exit For
End If
End If
Next 検索対象
0909向こうから ◆tr.t4dJfuU
NGNGDebug.Print "結果出力"
For k = 1 To 素数格納配列上限
'
Debug.Print k; "個目は、"; 素数配列(k)
Next
Debug.Print "以上"; 素数格納配列上限; "個の検索終了)"
SOSUU = "完了"
End Function
0910向こうから ◆tr.t4dJfuU
NGNG1 個目は、 2
2 個目は、 3
3 個目は、 5
4 個目は、 7
5 個目は、 11
6 個目は、 13
7 個目は、 17
略
22 個目は、 79
23 個目は、 83
24 個目は、 89
25 個目は、 97
26 個目は、 101
27 個目は、 103
28 個目は、 107
29 個目は、 109
30 個目は、 113
以上 30 個の検索終了)
多分 いいと おもいます
0911名無しさん@お腹いっぱい。
NGNG#include<stdio.h>
main()
{
int k,i;
for(i=1;i<352;i++){
if((i*352+1)%109==0) {i=352;k=(i*352+1)/109;}
}
printf("%d\n",k);
}
cですがこんな感じです
0912向こうから ◆tr.t4dJfuU
NGNGん?
わかりそうで わかりません 構文の意味からして・・・
こんなんは どうですか?
for i=1 to 352
if (i*109) mod 352 =1 then
print i
endif
next
すみません 今日はこのへんまでに しておきます
また、暗号で話してるかたには スレ消費して すみません。
0913名無しさん@お腹いっぱい。
NGNGそれだとdが見つからないです
なぜならeが小さい場合dは大抵大きな数になるからです
くり返しが多くなってしまい効率が悪くなります
その構文で書くならば
for i=1 to 352
if (i*352+1) mod 109 = 0 then
print i
endif
next
にした方がいいです
0914名無しさん@お腹いっぱい。
NGNG訂正です
for i=1 to 352
if (i*352+1) mod 109 = 0 then
print (i*352+1)/109
endif
next
0915向こうから ◆tr.t4dJfuU
NGNGんんん???
(i*352+1) mod 109 = 0 と
(i*109) mod 352 =1 は
同じなんですか?
違うんですか?
言葉で 現すと どんな感じでしょう?
ちょっと 風呂はいります・・・ 悩む(w
0916向こうから ◆tr.t4dJfuU
NGNGよけい こんらんです(w
風呂いきます
0917名無しさん@お腹いっぱい。
NGNGこう考えてみてください
s=2898443842392832878
e=5
の場合どちらの方が効率がいいのかわかると思います
0918向こうから ◆tr.t4dJfuU
NGNGえっと、
意味がしりたいのです
漏れのは、そのまま
i*109 を 352 で 割った 余りが 1 に なった時の i を 見つける
(繰り返しの上限は 352回では 足りないかもしれないけど)
意味か・・
もしくは
両辺を109 で 割って・・
両辺から1引いて・・
・・・・
みたいに、その判定式で i(dのこと)が導き出せる 確信が欲しいんです。
教えられた判定式を 意味も分からず 使うのは イヤなんです。
(すみません 生意気で)
暗号がやりたいのではなく、仕組に興味があるんです。。。
0919向こうから ◆tr.t4dJfuU
NGNG時間かけて 考えてみます・・・
0920名無しさん@お腹いっぱい。
NGNGa*b MOD c = 1 ‥‥‥(1)
⇒
∃a' s.t. (a'*c+1) MOD b = 0
∵
(1)より
a*b - 1 = a'*c
⇔
a*b = a'*c + 1
⇔
a = (a'*c + 1) ÷ b
∴(a'*c+1) MOD b = 0
0921名無しさん@お腹いっぱい。
NGNG>>912は
i*109 を 352 で 割った 余りが 1 に なった時の i を 見つける
です
>>914は
j*352+1 を 109 で 割った 余りが 0 に なった時の j を 見つける
[ちなみに i = (j*352+1)/9]
です
0922名無しさん@お腹いっぱい。
NGNG[ちなみに i = (j*352+1)/9] → [ちなみに i = (j*352+1)/109]
0923名無しさん@お腹いっぱい。
NGNGRSAの話なら、
s=(p-1)*(q-l)
ではなくて
s=LCM(p-1,q-1)
ではないのでつか?
0924向こうから ◆tr.t4dJfuU
NGNGなんとなく ・・・ でもないか・・・ むずいです・・
できたら 「∃a' s.t. 」の意味を 教えてください
自分で考えてたのは・・
d*109 が、 352の?倍 より 1少ない
↓
d*109+1 = 352の?倍
↓
行き詰まる・・・
もう少し >>920 を 考え(理解)させてください・・
今日は寝ます・・
0925向こうから ◆tr.t4dJfuU
NGNGこれは、OKです。
気づきました
0926名無しさん@お腹いっぱい。
NGNGそれでも合ってますね
s=φ(n)を求める方式しか知りませんでした
0927名無しさん@お腹いっぱい。
NGNGBI=4567
IF B>A
THEN
A=BI
B=AI
ELSE
A=AI
B=BI
ENDIF
WHILE (A MOD B) != 0
X=A MOD B
A=B
B=X
ENDWHILE
IF B==1
THEN
PRINT AI ,"と",BI,"は互いに素"
ENDIF
0928名無しさん@お腹いっぱい。
NGNGユークリッドの互除法ですね
0929名無しさん@お腹いっぱい。
NGNG0930名無しさん@お腹いっぱい。
NGNGしてしまい、バックアップのFDも息子が
使ってしまい秘密鍵が完全になくなってしまいました。
サーバに登録してある公開鍵を削除したい
のですが、当然秘密鍵がないので、削除できません。
このような場合どうしたらよいでしょうか?
0931向こうから ◆tr.t4dJfuU
NGNG紙と鉛筆で いろいろ考え中です
0933932
NGNG「どうすることも出来ない」(のではないか?)と、932に付け加えておく。
0934向こうから ◆tr.t4dJfuU
NGNG!!!
小さい数字で・・・
p=3 、q=5
n= 3*5 = 15
s=(3-1)*(5-1) = 2 * 4 = 8
e=7 は 、8を割れない素数で 7 とする。
求めたいのは、
d*7 mod 8 = 1
余ってしまう1を、d*7から 引いておけば、余りは出ない。
↓
d*7-1 mod 8 = 0
d*7−1 は、8で割り切れる
いくつで割れるのかは不明なので、Xとすると、、、
↓
d*7−1 = 8*X ・・・・・式A
両辺に1を足して、
d*7 = 8*X+1
両辺を7で割ると、
d = (8*X+1)/7
8*X+1 を 7 で割ると、答えがdになるので、この割り算に 余りは 発生しない
だから、
8*X+1 mod 7 = 0 となる・・・・・・・
0935向こうから ◆tr.t4dJfuU
NGNGさらに、ここで 判明したX’(確定したXのこと)は、
式Aの X であるから、
d*7−1 = 8 * X’
↓
d*7 = 8 * X' +1
↓
d= (8 * X’ + 1)/7
>>918 と、>>924 を 併せて 考えました。
早速 打ち込みます(エクセルに)
0937名無しさん@お腹いっぱい。
NGNGばっちりです
ところでエクセルの桁数の上限はいくつですか?
0938名無しさん@お腹いっぱい。
NGNG493849238498129381298839284123981231みたいな数を
セルA1に4123981231
セルA2に8129883928
セルA3に2384981293
セルA4に493849
としてみたらどうでしょう
計算も工夫たらうまくいくと思います
レス数が900を超えています。1000を超えると表示できなくなるよ。