亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲蟲下載站

?? fgint.~pas

?? 經(jīng)典算法RSA,從其他地方得來的
?? ~PAS
?? 第 1 頁 / 共 3 頁
字號:
               If (Trest > 2147483647) Then rest := 0 Else rest := -1;
            End;
            size := size1;
            While (Sum.Number[size] = 0) And (size > 1) Do size := size - 1;
            If size < size1 Then
            Begin
               SetLength(Sum.Number, size + 1);
            End;
            Sum.Number[0] := size;
            Sum.Sign := FGInt1.Sign;
         End;
      End;
   End;
End;


Procedure FGIntChangeSign(Var FGInt : TFGInt);
Begin
   If FGInt.Sign = negative Then FGInt.Sign := positive Else FGInt.Sign := negative;
End;


// Substract 2 FGInts, FGInt1 - FGInt2 = dif

Procedure FGIntSub(Var FGInt1, FGInt2, dif : TFGInt);
Begin
   FGIntChangeSign(FGInt2);
   FGIntAdd(FGInt1, FGInt2, dif);
   FGIntChangeSign(FGInt2);
End;


// multiply a FGInt by an integer, FGInt * by = res, by < 1000000000

Procedure FGIntMulByInt(Const FGInt : TFGInt; Var res : TFGInt; by : int64);
Var
   i, size : longint;
   Trest, rest : int64;
Begin
   size := FGInt.Number[0];
   SetLength(res.Number, size + 2);
   rest := 0;
   For i := 1 To size Do
   Begin
      Trest := FGInt.Number[i] * by + rest;
      res.Number[i] := Trest And 2147483647;
      rest := Trest Shr 31;
   End;
   If rest <> 0 Then
   Begin
      size := size + 1;
      Res.Number[size] := rest;
   End
   Else SetLength(Res.Number, size + 1);
   Res.Number[0] := size;
   Res.Sign := FGInt.Sign;
End;


// multiply a FGInt by an integer, FGInt * by = res, by < 1000000000

Procedure FGIntMulByIntbis(Var FGInt : TFGInt; by : int64);
Var
   i, size : longint;
   Trest, rest : int64;
Begin
   size := FGInt.Number[0];
   SetLength(FGInt.Number, size + 2);
   rest := 0;
   For i := 1 To size Do
   Begin
      Trest := FGInt.Number[i] * by + rest;
      FGInt.Number[i] := Trest And 2147483647;
      rest := Trest Shr 31;
   End;
   If rest <> 0 Then
   Begin
      size := size + 1;
      FGInt.Number[size] := rest;
   End
   Else SetLength(FGInt.Number, size + 1);
   FGInt.Number[0] := size;
End;


// divide a FGInt by an integer, FGInt = res * by + modres

Procedure FGIntDivByInt(Const FGInt : TFGInt; Var res : TFGInt; by : int64; Var modres : int64);
Var
   i, size : longint;
   rest : int64;
Begin
   size := FGInt.Number[0];
   SetLength(res.Number, size + 1);
   modres := 0;
   For i := size Downto 1 Do
   Begin
      modres := modres Shl 31;
      rest := modres Or FGInt.Number[i];
      res.Number[i] := rest Div by;
      modres := rest Mod by;
   End;
   While (res.Number[size] = 0) And (size > 1) Do size := size - 1;
   SetLength(res.Number, size + 1);
   res.Number[0] := size;
   Res.Sign := FGInt.Sign;
End;


// divide a FGInt by an integer, FGInt = FGInt * by + modres

Procedure FGIntDivByIntBis(Var FGInt : TFGInt; by : int64; Var modres : int64);
Var
   i, size : longint;
   rest : int64;
Begin
   size := FGInt.Number[0];
   modres := 0;
   For i := size Downto 1 Do
   Begin
      modres := modres Shl 31;
      rest := modres Or FGInt.Number[i];
      FGInt.Number[i] := rest Div by;
      modres := rest Mod by;
   End;
   While (FGInt.Number[size] = 0) And (size > 1) Do size := size - 1;
   If size <> FGInt.Number[0] Then
   Begin
      SetLength(FGInt.Number, size + 1);
      FGInt.Number[0] := size;
   End;
End;


// Reduce a FGInt modulo by (=an integer), FGInt mod by = modres

Procedure FGIntModByInt(Const FGInt : TFGInt; by : int64; Var modres : int64);
Var
   i, size : longint;
   rest : int64;
Begin
   size := FGInt.Number[0];
   modres := 0;
   For i := size Downto 1 Do
   Begin
      modres := modres Shl 31;
      rest := modres + FGInt.Number[i];
      modres := rest Mod by;
   End;
End;


// Returns the FGInt in absolute value

Procedure FGIntAbs(Var FGInt : TFGInt);
Begin
   FGInt.Sign := positive;
End;


// Copy a FGInt1 into FGInt2

Procedure FGIntCopy(Const FGInt1 : TFGInt; Var FGInt2 : TFGInt);
Begin
   FGInt2.Sign := FGInt1.Sign;
   FGInt2.Number := Nil;
   FGInt2.Number := Copy(FGInt1.Number, 0, FGInt1.Number[0] + 1);
End;


// Shift the FGInt to the left in base 2 notation, ie FGInt = FGInt * 2

Procedure FGIntShiftLeft(Var FGInt : TFGInt);
Var
   l, m : int64;
   i, size : longint;
Begin
   size := FGInt.Number[0];
   l := 0;
   For i := 1 To Size Do
   Begin
      m := FGInt.Number[i] Shr 30;
      FGInt.Number[i] := ((FGInt.Number[i] Shl 1) Or l) And 2147483647;
      l := m;
   End;
   If l <> 0 Then
   Begin
      setlength(FGInt.Number, size + 2);
      FGInt.Number[size + 1] := l;
      FGInt.Number[0] := size + 1;
   End;
End;


// Shift the FGInt to the right in base 2 notation, ie FGInt = FGInt div 2

Procedure FGIntShiftRight(Var FGInt : TFGInt);
Var
   l, m : int64;
   i, size : longint;
Begin
   size := FGInt.Number[0];
   l := 0;
   For i := size Downto 1 Do
   Begin
      m := FGInt.Number[i] And 1;
      FGInt.Number[i] := (FGInt.Number[i] Shr 1) Or l;
      l := m Shl 30;
   End;
   If (FGInt.Number[size] = 0) And (size > 1) Then
   Begin
      setlength(FGInt.Number, size);
      FGInt.Number[0] := size - 1;
   End;
End;


// FGInt = FGInt / 2147483648

Procedure FGIntShiftRightBy31(Var FGInt : TFGInt);
Var
   size : longint;
Begin
   size := FGInt.Number[0];
   If size > 1 Then
   Begin
      FGInt.Number := Copy(FGInt.Number, 1, Size);
      FGInt.Number[0] := size - 1;
   End
   Else FGInt.Number[1] := 0;
End;


// FGInt1 = FGInt1 + FGInt2, FGInt1 > FGInt2

Procedure FGIntAddBis(Var FGInt1 : TFGInt; Const FGInt2 : TFGInt);
Var
   i, size1, size2 : longint;
   rest : integer;
   Trest : int64;
Begin
   size1 := FGInt1.Number[0];
   size2 := FGInt2.Number[0];
   rest := 0;
   For i := 1 To size2 Do
   Begin
      Trest := FGInt1.Number[i] + FGInt2.Number[i] + rest;
      rest := Trest Shr 31;
      FGInt1.Number[i] := Trest And 2147483647;
   End;
   For i := size2 + 1 To size1 Do
   Begin
      Trest := FGInt1.Number[i] + rest;
      rest := Trest Shr 31;
      FGInt1.Number[i] := Trest And 2147483647;
   End;
   If rest <> 0 Then
   Begin
      SetLength(FGInt1.Number, size1 + 2);
      FGInt1.Number[0] := size1 + 1;
      FGInt1.Number[size1 + 1] := rest;
   End;
End;


// FGInt1 = FGInt1 - FGInt2, use only when 0 < FGInt2 < FGInt1

Procedure FGIntSubBis(Var FGInt1 : TFGInt; Const FGInt2 : TFGInt);
Var
   i, size1, size2 : longint;
   rest : integer;
   Trest : int64;
Begin
   size1 := FGInt1.Number[0];
   size2 := FGInt2.Number[0];
   rest := 0;
   For i := 1 To size2 Do
   Begin
      Trest := 2147483648 + FGInt1.Number[i] - FGInt2.Number[i] + rest;
      If (Trest > 2147483647) Then rest := 0 Else rest := -1;
      FGInt1.Number[i] := Trest And 2147483647;
   End;
   For i := size2 + 1 To size1 Do
   Begin
      Trest := 2147483648 + FGInt1.Number[i] + rest;
      If (Trest > 2147483647) Then rest := 0 Else rest := -1;
      FGInt1.Number[i] := Trest And 2147483647;
   End;
   i := size1;
   While (FGInt1.Number[i] = 0) And (i > 1) Do i := i - 1;
   If i < size1 Then
   Begin
      SetLength(FGInt1.Number, i + 1);
      FGInt1.Number[0] := i;
   End;
End;


// Multiply 2 FGInts, FGInt1 * FGInt2 = Prod

Procedure FGIntMul(Const FGInt1, FGInt2 : TFGInt; Var Prod : TFGInt);
Var
   i, j, size, size1, size2 : longint;
   rest, Trest : int64;
Begin
   size1 := FGInt1.Number[0];
   size2 := FGInt2.Number[0];
   size := size1 + size2;
   SetLength(Prod.Number, size + 1);
   For i := 1 To size Do Prod.Number[i] := 0;

   For i := 1 To size2 Do
   Begin
      rest := 0;
      For j := 1 To size1 Do
      Begin
         Trest := Prod.Number[j + i - 1] + FGInt1.Number[j] * FGInt2.Number[i] + rest;
         Prod.Number[j + i - 1] := Trest And 2147483647;
         rest := Trest Shr 31;
      End;
      Prod.Number[i + size1] := rest;
   End;

   Prod.Number[0] := size;
   While (Prod.Number[size] = 0) And (size > 1) Do size := size - 1;
   If size < Prod.Number[0] Then
   Begin
      SetLength(Prod.Number, size + 1);
      Prod.Number[0] := size;
   End;
   If FGInt1.Sign = FGInt2.Sign Then Prod.Sign := Positive Else prod.Sign := negative;
End;


// Square a FGInt, FGInt

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
成人午夜激情片| 亚洲午夜久久久久久久久久久 | 国产亚洲视频系列| 美国欧美日韩国产在线播放| 日韩一区二区三区精品视频 | 一区二区三区精品久久久| 9久草视频在线视频精品| 亚洲欧美日本在线| 欧美在线free| 麻豆视频一区二区| 中文成人综合网| 色综合久久久久| 人人精品人人爱| 国产精品丝袜91| 色爱区综合激月婷婷| 奇米影视一区二区三区小说| 久久久美女艺术照精彩视频福利播放| 国产精品一区二区黑丝| 亚洲天堂2014| 5月丁香婷婷综合| 国产精品系列在线观看| 亚洲欧美日韩国产中文在线| 91精品国产色综合久久不卡蜜臀| 韩国精品在线观看| 亚洲视频综合在线| 欧美一级理论片| av不卡一区二区三区| 天天影视涩香欲综合网| 亚洲国产成人私人影院tom| 欧美视频一区二区三区四区| 国产成人午夜精品影院观看视频| 国产精品午夜免费| 国产日韩精品一区| 亚洲不卡在线观看| 久久久久综合网| 在线精品视频一区二区三四| 精品影视av免费| 亚洲激情五月婷婷| 91精品国产黑色紧身裤美女| 成人午夜激情在线| 免费在线观看日韩欧美| 亚洲视频中文字幕| 精品久久久久久久久久久久包黑料| 91在线观看下载| 激情都市一区二区| 亚洲成av人在线观看| 亚洲欧美自拍偷拍色图| 精品乱人伦小说| 在线观看免费亚洲| heyzo一本久久综合| 精品一区二区三区在线播放视频| 成人欧美一区二区三区白人| 精品国产一区二区三区不卡| 在线观看亚洲a| 97超碰欧美中文字幕| 激情偷乱视频一区二区三区| 亚洲va韩国va欧美va精品| 国产精品久久久久影视| 欧美变态tickling挠脚心| 欧美色窝79yyyycom| av网站免费线看精品| 国产91丝袜在线18| 狠狠色综合日日| 蜜臀99久久精品久久久久久软件| 亚洲aaa精品| 婷婷一区二区三区| 亚洲超丰满肉感bbw| 亚洲午夜电影在线观看| 亚洲三级久久久| 日韩毛片一二三区| 亚洲欧洲性图库| 1区2区3区欧美| 亚洲精选视频在线| 亚洲蜜臀av乱码久久精品| 国产精品国产三级国产aⅴ中文 | 亚洲国产精品t66y| 亚洲国产精品av| 国产精品福利电影一区二区三区四区| wwww国产精品欧美| 久久综合色之久久综合| 精品欧美一区二区久久| 久久久久国产一区二区三区四区| 91麻豆精品国产91久久久久久| 精品视频在线免费观看| 在线观看视频一区二区欧美日韩| 欧洲av一区二区嗯嗯嗯啊| 欧美午夜精品一区二区三区| 欧美日韩一区二区三区高清 | 亚洲成人免费av| 亚洲成人资源在线| 日韩主播视频在线| 国产一区二区三区免费播放| 国产v综合v亚洲欧| 91视频在线观看免费| 91成人国产精品| 91精品国产一区二区人妖| 欧美sm极限捆绑bd| 欧美极品少妇xxxxⅹ高跟鞋| 国产精品视频免费| 亚洲一区av在线| 美女网站视频久久| 成人一级片网址| 91电影在线观看| 日韩午夜在线观看视频| 中文字幕欧美国产| 亚洲mv在线观看| 久久精品999| 99久久久久久| 欧美剧情片在线观看| 久久久不卡网国产精品二区| 中文字幕欧美一| 日本欧美肥老太交大片| 福利91精品一区二区三区| 色综合天天综合色综合av| 日韩一区二区三区视频在线 | 99v久久综合狠狠综合久久| 欧美人xxxx| 国产精品欧美久久久久一区二区 | 欧美日韩大陆在线| 久久午夜免费电影| 亚洲一区视频在线| 国产精品亚洲专一区二区三区| 色婷婷亚洲精品| 久久九九99视频| 日本成人中文字幕| 色综合久久久久| 国产亚洲一区二区在线观看| 丝袜美腿成人在线| 97se亚洲国产综合在线| 精品久久久久av影院| 亚洲狠狠爱一区二区三区| 国产成人一级电影| 日韩一区二区三区视频在线观看 | 国产亚洲一区二区三区四区| 亚洲成人av在线电影| 成人91在线观看| 精品福利一区二区三区免费视频| 亚洲夂夂婷婷色拍ww47 | 99国产精品久久久久久久久久 | 成人激情文学综合网| 日韩欧美综合在线| 亚洲大片在线观看| 色94色欧美sute亚洲线路一ni| 久久久精品国产免大香伊| 日日嗨av一区二区三区四区| 91国偷自产一区二区三区成为亚洲经典| 欧美成人一级视频| 日韩国产欧美在线播放| 在线视频亚洲一区| 一区二区三区资源| 99re热这里只有精品免费视频| 久久亚洲综合色一区二区三区| 日韩综合小视频| 欧美精品在线一区二区三区| 亚洲欧美日韩电影| 日本精品一区二区三区高清| 国产精品福利电影一区二区三区四区| 国产麻豆精品一区二区| 精品日韩一区二区| 久久不见久久见中文字幕免费| 欧美色图一区二区三区| 亚洲国产一区视频| 欧美日韩精品系列| 三级久久三级久久久| 欧美日韩你懂的| 午夜视频在线观看一区二区三区| 色综合天天性综合| 亚洲日本丝袜连裤袜办公室| 91啦中文在线观看| 一区二区三区在线视频观看58 | 国产成人一级电影| 国产欧美日韩精品a在线观看| 国产黄色精品网站| 国产欧美日韩三级| 色综合天天天天做夜夜夜夜做| 亚洲蜜臀av乱码久久精品| 欧美视频在线观看一区二区| 丝袜美腿亚洲综合| 欧美成人a∨高清免费观看| 国产麻豆视频精品| 中文字幕在线观看一区二区| 99精品视频在线免费观看| 亚洲精品国产一区二区精华液 | 国产亚洲精品免费| 成人精品视频.| 一区二区三区日本| 欧美一区二区视频在线观看| 久久精品久久精品| 国产精品美女久久久久av爽李琼| 99久久免费精品高清特色大片| 亚洲免费av高清| 欧美一卡二卡在线观看| 国产露脸91国语对白| 亚洲特黄一级片| 欧美精品第一页| 成人美女在线观看| 亚洲一区中文日韩| 久久久噜噜噜久久人人看 | 亚洲国产乱码最新视频| 日韩情涩欧美日韩视频|