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

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? bignum.java

?? 手機上進行RSA加密的算法
?? JAVA
?? 第 1 頁 / 共 4 頁
字號:
package rsa;import java.io.PrintStream;/** * <p>Title: </p> * <p>Description: </p> * <p>Copyright: Copyright (c) 2003</p> * <p>Company: </p> * @author not attributable * @version 1.0 */public class BigNum //implements myCloneable{        private static final String LIBRARY_NAME = "bignum";        private static boolean native_link_ok = false;        private static boolean native_lib_loaded = false;        private static String native_link_err = "Class not loaded";        private static BigNum staticZero;        private static BigNum staticOne;/*        static        {                // load the DLL or shared library that contains the native code                try                {                       System.loadLibrary( LIBRARY_NAME );                        native_lib_loaded = true;                        try                        {                                //                                //	Should really do a bit more testing than this ...                                //                                if (bignum_test() == 0)                                {                                        // create a static BigNum that will be set to one.                                        native_link_ok = true;                                        native_link_err = null;                                        staticOne = new BigNum();                                        staticOne.setToOne();                                }                                else                                {                                        native_link_err = "Self test failed";                                }                        }                        catch ( UnsatisfiedLinkError ule )                        {                                native_link_err = "Errors linking to " + LIBRARY_NAME + " native library";                        }                }                catch ( UnsatisfiedLinkError ule )                {                        native_link_err = "The " + LIBRARY_NAME + " native library was not found";                }        }*/        public final static boolean        hasFileLibraryLoaded()        {                return native_lib_loaded;        }        public final static boolean        isLibraryCorrect()        {                return native_link_ok;        }        public final static String        getLinkErrorString()        {                return native_link_err;        }        //        //	Constants        //        // If LONG        // static final int BITS = 62; // Not 63, since we dont have unsigned        // static final long RADIX = (1L << BITS);        // static final long MASK = RADIX-1;        // static final int LBITS = BITS/2;        // static final long LRADIX = (1L << LBITS);        // static final long LMASK = LRADIX-1;        // If not LONG        static final int BITS = 30;        static final int RADIX = (1 << BITS);        static final int MASK = RADIX-1;        static final int LBITS = BITS/2;        static final int LRADIX = (1 << LBITS);        static final int LMASK = LRADIX-1;        //        //	Data members for Java implementation        //        // If LONG        // private long n[];        // If not LONG        private int n[];        private int len;        private boolean negative;        //        //	Data members for native implementation        //        private int pointer_; // N.B. may need to be long if running on a 64bit machine        public int byteLength()        {                        int r = ((len - 1) * BITS)/8;                        // If LONG                        // long i = n[0];                        // If not LONG                        int i = n[0];                        while (i != 0)                        {                                i >>>= 8;                                ++r;                        }                        return r;        }        public void check_state()        {                bitLength(this);        }        public static        int bitLength(BigNum n)        {                        int len = n.len;                        if (len == 0)                                return 0;                        int r = (len - 1) * BITS;                        // If LONG                        // long i = n.n[len-1];                        // If not LONG                        int i = n.n[len-1];                        // Could probably speed this up with a binary search                        while (i != 0)                        {                                i >>>= 1;                                ++r;                        }// For debugging onlyif (r == 0) throw new MathError("Invalid state");                        return r;        }        public static        boolean bit(BigNum n, int i)        {                        int bit = i % BITS;                        i /= BITS;                        if (i >= n.len || ((n.n[i] & (1L << bit)) == 0))                                return false;                        return true;        }        protected BigNum()        {                        // If LONG                        // n = new long[8];	// 512 bits (nearly)                        // If not LONG                        n = new int[16];	// 512 bits (nearly)                        len = 0;                        negative = false;        }        public Object        clone()        {                BigNum r = new BigNum();                copy(r, this);                return r;        }        public void        copy(Object src)        {                copy(this, (BigNum)src);        }        protected static void        copy(BigNum dst, BigNum src)        {                if (dst == src)                        return;                        // throw new IllegalArgumentException();                   // If LONG                        // dst.n = new long[src.n.length];                        // If not LONG                        dst.n = new int[src.n.length];                        dst.negative = src.negative;                        dst.len = src.len;                        if (src.len > 0)                                System.arraycopy(src.n, 0, dst.n, 0, src.len);        }        public static void        grow(BigNum a, int i)        {                        // If LONG                        // long an[] = a.n;                        // If not LONG                        int an[] = a.n;                        if (i <= an.length)                                return;                        i += 16; // Add 8 or 16 for efficiency                        // If LONG                        // long n[] = new long[i];                        // If not LONG                        int n[] = new int[i];                        System.arraycopy(an, 0, n, 0, an.length);                        a.n = n;        }        public int        intoBinary(byte buffer[])        {                        int len = (bitLength(this)+7)/8;                        if (buffer.length < (len))                                throw new MathError("into-binary buffer too small");                        int pos = 0;                        int bitpos = 0;                        // Index in reverse to get LSB first                        for (int i = len-1; i >= 0; --i)                        {                                int b = (int)((n[pos] >>> bitpos) & 0xFFL);                                bitpos += 8;                                if (bitpos >= BITS)                                {                                        bitpos -= BITS;                                        pos++;                                        if (bitpos > 0)                                                b |= (n[pos] << (8-bitpos)) & 0xFFL;                                }                                buffer[i] = (byte)b;                        }                        return len;        }        protected void        fromBinary(byte buffer[])        {                        negative = false;	// Can't init negatives yet                        len = ((buffer.length)*8 + BITS-1) / BITS;                        grow(this, len);                        int pos = 0;                        n[pos] = 0;                        int bitpos = 0;                        // Index in reverse to get LSB first                        for (int i = buffer.length-1; i >= 0; --i)                        {                                // If LONG                                // long b = buffer[i] & 0xFF;                                // If not LONG                                int b = buffer[i] & 0xFF;                                n[pos] |= (b << bitpos) & MASK;                                bitpos += 8;                                if (bitpos >= BITS)                                {                                        pos++;                                        n[pos] = 0;                                        bitpos -= BITS;                                        if (bitpos > 0)                                                n[pos] = b >>> (8-bitpos);                                }                        }                        while (len > 0 && n[len-1] == 0)                                len--;        }        public static void        assign(BigNum r, int val)        {                        if (val != 0)                        {                                r.len = 1;                                // If LONG                                // r.n[0] = val & 0x7FFFFFFFL;                                // If not LONG                                r.n[0] = val & 0x7FFFFFFF;                                r.negative = (val < 0);                        }                        else                        {                                r.len = 0;                                r.n[0] = 0;                                r.negative = false;                        }        }        public static void        zero(BigNum a)        {                        a.n[0] = 0;                        a.negative = false;                        a.len = 0;        }        public static void        one(BigNum a)        {                        a.n[0] = 1;                        a.negative = false;                        a.len = 1;        }        public static boolean        isOne(BigNum a)        {                        return (a.len == 1 && a.n[0] == 1);        }        public static boolean        even(BigNum a)        {                        return !(a.len > 0 && (a.n[0] & 1) == 1);        }        public static boolean        odd(BigNum a)        {                        return (a.len > 0 && (a.n[0] & 1) == 1);        }        public static boolean        isZero(BigNum a)        {                        if (a.len == 0) return true;a.check_state();                        // if (a.len > 1) return false;                        // return (a.n[0] == 0);                        return false;        }        public static void        inc(BigNum a)        {                add(a, 1);        }        public static void        dec(BigNum a)        {                sub(a, 1);        }        public static void        add( BigNum r, int a )        {                if (a == 0)                        return;                        if (a < 0)                        {                                if (r.negative)                                {                                        r.negative = false;                                        add_unsigned(r, -a);                                        r.negative = true;                                }                                else                                {                                        sub_unsigned(r, -a);                                }                        }                        else                        {                                if (r.negative)                                {

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
jlzzjlzz欧美大全| 欧美高清精品3d| 日韩在线一二三区| 久久精品亚洲精品国产欧美kt∨| 色又黄又爽网站www久久| 免费欧美高清视频| 亚洲精品成人悠悠色影视| 久久美女高清视频| 538在线一区二区精品国产| 国产成人免费视频网站| 日韩av高清在线观看| 亚洲精品国久久99热| 欧美国产日韩在线观看| 日韩欧美一区电影| 欧美精品乱码久久久久久| 97aⅴ精品视频一二三区| 国产尤物一区二区| 男女男精品视频网| 午夜精品福利在线| 一区二区三区四区不卡在线| 欧美国产一区视频在线观看| 日韩免费高清av| 91精品久久久久久久久99蜜臂| 在线免费av一区| 99re热这里只有精品视频| 国产成人午夜高潮毛片| 国产精品中文有码| 国产在线一区观看| 国内精品写真在线观看| 麻豆精品蜜桃视频网站| 日本视频一区二区| 日本中文在线一区| 日本在线播放一区二区三区| 亚洲国产精品欧美一二99| 亚洲精品日韩一| 夜夜揉揉日日人人青青一国产精品| 一区在线中文字幕| 亚洲欧美日韩综合aⅴ视频| 亚洲天堂av老司机| 亚洲人成网站色在线观看 | 欧美激情在线一区二区三区| 精品日产卡一卡二卡麻豆| 欧美一区二区三区免费| 欧美一区二区三区免费在线看| 欧美一区二区三区视频免费| 日韩欧美国产wwwww| 日韩欧美一卡二卡| 久久夜色精品国产欧美乱极品| 久久久www成人免费无遮挡大片| 久久夜色精品国产噜噜av| 国产无人区一区二区三区| 国产女人水真多18毛片18精品视频 | gogo大胆日本视频一区| 99精品视频在线免费观看| 色婷婷久久一区二区三区麻豆| 在线免费观看日本欧美| 欧美日韩午夜影院| 欧美大白屁股肥臀xxxxxx| 精品国产凹凸成av人导航| 久久这里只有精品首页| 中文字幕一区免费在线观看| 亚洲日穴在线视频| 五月天激情小说综合| 激情综合色播五月| 波多野结衣视频一区| 欧美色爱综合网| 久久综合中文字幕| 亚洲欧美福利一区二区| 午夜精品一区二区三区电影天堂 | 黑人精品欧美一区二区蜜桃| 国产一区二区三区电影在线观看 | 欧美日韩国产在线播放网站| 日韩欧美国产三级电影视频| 国产精品私人自拍| 亚洲一区在线观看免费 | 黄色日韩网站视频| 成人av网站免费观看| 欧美日韩视频在线一区二区| 精品久久一区二区三区| 亚洲精品综合在线| 另类小说图片综合网| 99精品在线观看视频| 69堂亚洲精品首页| 国产精品美女久久久久aⅴ| 天天色 色综合| av色综合久久天堂av综合| 717成人午夜免费福利电影| 国产欧美一区二区精品仙草咪| 亚洲成人资源在线| 大胆亚洲人体视频| 欧美一二三区精品| 亚洲精品写真福利| 国产成人av自拍| 欧美老女人在线| 综合激情成人伊人| 狠狠色丁香久久婷婷综合_中| 97se亚洲国产综合自在线观| 日韩欧美国产一区二区在线播放| 自拍偷拍欧美激情| 国产九九视频一区二区三区| 精品视频999| 亚洲免费观看高清在线观看| 国内精品写真在线观看| 777奇米四色成人影色区| 亚洲欧洲色图综合| 国产高清不卡二三区| 欧美一级黄色片| 亚洲一区二区中文在线| 99久久精品免费看国产免费软件| 欧美电影免费观看高清完整版在线观看 | 麻豆精品久久久| 欧美精品在线一区二区三区| 亚洲三级在线看| 丰满少妇久久久久久久| 精品少妇一区二区| 日本最新不卡在线| 555www色欧美视频| 午夜成人免费视频| 欧美色偷偷大香| 一区二区高清视频在线观看| 99精品视频在线播放观看| 国产欧美日韩另类一区| 国产乱码精品一品二品| 久久综合狠狠综合久久综合88 | 在线观看免费亚洲| 亚洲视频资源在线| 99久久免费视频.com| 国产精品久久精品日日| 成人a免费在线看| 中文字幕精品—区二区四季| 国产一区二区三区在线观看精品 | 国产精品免费人成网站| 成人激情开心网| 国产精品亲子乱子伦xxxx裸| 丁香婷婷深情五月亚洲| 欧美国产97人人爽人人喊| 成人免费高清视频| 国产精品女主播在线观看| 波多野结衣中文字幕一区二区三区| 国产亚洲精品久| 不卡免费追剧大全电视剧网站| 国产欧美日本一区二区三区| 粉嫩av一区二区三区在线播放| 日本一区二区免费在线| 成人一道本在线| 亚洲精品视频在线观看网站| 欧美自拍偷拍一区| 日本午夜精品视频在线观看| 精品精品欲导航| 国产高清亚洲一区| 国产精品精品国产色婷婷| 91浏览器在线视频| 亚洲一区二区av电影| 91精品国产综合久久久久| 精品亚洲成a人在线观看| 国产情人综合久久777777| 91在线码无精品| 婷婷成人激情在线网| 精品成人免费观看| 91亚洲精品一区二区乱码| 亚洲一区二区三区在线看| 日韩一级高清毛片| 国产激情一区二区三区四区| 亚洲日本韩国一区| 欧美一区二区视频在线观看| 激情五月婷婷综合网| 国产精品高潮久久久久无| 欧美在线短视频| 精品一区二区三区免费毛片爱| 国产精品大尺度| 制服视频三区第一页精品| 国产福利一区二区三区| 亚洲黄色录像片| 欧美成va人片在线观看| jlzzjlzz欧美大全| 日本最新不卡在线| 中文字幕在线免费不卡| 欧美精品xxxxbbbb| 高清不卡在线观看| 天堂影院一区二区| 国产精品视频第一区| 欧美日韩精品一区二区在线播放| 国产一区二区女| 亚洲成年人网站在线观看| 中文字幕av免费专区久久| 5858s免费视频成人| 91视频xxxx| 国产在线精品一区二区三区不卡 | 国产精品一区二区在线观看网站| 亚洲人成精品久久久久| 日韩欧美在线网站| 91福利视频在线| 国产69精品一区二区亚洲孕妇| 亚洲一卡二卡三卡四卡 | 国产无一区二区| 欧美一区二区三区思思人| 日本乱人伦aⅴ精品| 国产成人福利片| 精品中文av资源站在线观看| 亚洲成人激情自拍|