• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>

            Why so serious? --[NKU]schindlerlee

            一個(gè)高精度乘法的例子

            文本是schindlerlee原創(chuàng),查看原文請(qǐng)?jiān)L問
            m.shnenglu.com/schindlerlee
            轉(zhuǎn)載請(qǐng)保留此信息,本人保留關(guān)于本文的一切信息
            const int PRECISION = 525;
            const int SENTINAL = 0x7fffffff;

            struct bignum {
                
            int s[PRECISION];
                
            int len;
                
            void reset() {
                    
            for (int i = 0; i < PRECISION; i++) {
                        s[i] 
            = SENTINAL;
                    } len 
            = 0;
                }
            };

            void justify(bignum & a, int step)
                
            /*
                 * 調(diào)整乘法產(chǎn)生的結(jié)果
                 * 例如將:
                 *-------------------------------------------------------------
                 *| 64 | 64 |SENT|SENT|SENT|SENT|SENT|SENT|SENT|SENT|SENT|SENT|
                 *-------------------------------------------------------------
                 *調(diào)整為
                 *-------------------------------------------------------------
                 *| 4  | 0  | 7  |SENT|SENT|SENT|SENT|SENT|SENT|SENT|SENT|SENT|
                 *-------------------------------------------------------------
                 * 
            */
            {
                
            if (step < PRECISION && a.s[step] != SENTINAL) {
                    
            if (a.s[step] > 9) {
                        
            if (a.s[step + 1== SENTINAL)
                            a.s[step 
            + 1= 0;
                        a.s[step 
            + 1+= a.s[step] / 10;
                        a.s[step] 
            = a.s[step] % 10;
                    }
                    justify(a, step 
            + 1);
                } 
            else {
                    a.len 
            = step;
                    
            for (int i = step; i < PRECISION; i++) {
                        a.s[i] 
            = SENTINAL;
                    }
                }
            }

            void mul(bignum a, bignum b, bignum & c)    //a b result
            {
                
            int i, j;
                c.reset();
                
            for (i = 0; i < a.len; i++) {
                    
            for (j = 0; j < b.len; j++) {
                        
            if(i+< PRECISION) {
                            
            if (c.s[i + j] == SENTINAL) c.s[i + j] = 0;
                            c.s[i 
            + j] += a.s[i] * b.s[j];
                        }
                    }
                }
                justify(c, 
            0);
            }

            posted on 2009-05-28 11:08 schindlerlee 閱讀(330) 評(píng)論(0)  編輯 收藏 引用


            只有注冊(cè)用戶登錄后才能發(fā)表評(píng)論。
            網(wǎng)站導(dǎo)航: 博客園   IT新聞   BlogJava   博問   Chat2DB   管理


            久久综合狠狠综合久久97色| 久久美女人爽女人爽| 久久国产色AV免费观看| 色综合合久久天天给综看| 久久久久久精品免费看SSS| 日韩精品久久久久久久电影蜜臀| 久久久久99精品成人片欧美| 亚洲七七久久精品中文国产| 久久精品国产亚洲AV高清热| 岛国搬运www久久| 日本五月天婷久久网站| 国产V综合V亚洲欧美久久| 久久国产精品视频| 色婷婷综合久久久中文字幕 | 国产精品久久久久久影院| 国产精品无码久久久久久| 美女久久久久久| 久久夜色tv网站| 久久毛片一区二区| 精品国产乱码久久久久久浪潮| 日韩AV毛片精品久久久| 无码久久精品国产亚洲Av影片 | 国内精品欧美久久精品| 成人综合久久精品色婷婷| 久久亚洲精品国产精品| 久久婷婷色综合一区二区| 国产成人精品久久亚洲高清不卡 | 久久久精品人妻一区二区三区蜜桃| 久久99国产综合精品女同| 欧美性大战久久久久久| 成人久久综合网| 久久久久AV综合网成人| 少妇久久久久久被弄高潮| 亚洲精品乱码久久久久久中文字幕 | 亚洲精品午夜国产VA久久成人| 国产精品综合久久第一页| 久久久久久国产精品无码下载 | 亚洲午夜久久久影院| 日本精品久久久久影院日本| 99久久精品免费看国产一区二区三区 | 人人狠狠综合久久亚洲|