• <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>

            The Fourth Dimension Space

            枯葉北風(fēng)寒,忽然年以殘,念往昔,語默心酸。二十光陰無一物,韶光賤,寐難安; 不畏形影單,道途阻且慢,哪曲折,如渡飛湍。斬浪劈波酬壯志,同把酒,共言歡! -如夢令

            HDOJ 2466 Cryptography Reloaded (RSA算法)

            給出N,e,d,3<=e<31,求出p,q;


            二分給BigInteger開方很好用。
            另外就是枚舉(p-1)*(q-1)在比賽的時候也不失為一種很不錯的方法。
            import java.math.*;
            import java.util.*;
            import java.io.*;


            public class Main
            {
                
            public static BigInteger Sqrt(BigInteger x)
                {
                    BigInteger l
            =new BigInteger("0");
                    BigInteger r
            =x;
                    
            while(l.compareTo(r)<0)
                    {
                        BigInteger mid
            =l.add(r).divide(BigInteger.valueOf(2));
                        
            if(mid.multiply(mid).compareTo(x)<0)
                            l
            =mid.add(BigInteger.ONE);
                        
            else if(mid.multiply(mid).compareTo(x)==0)
                            
            return mid;
                        
            else

                            r
            =mid.subtract(BigInteger.ONE);
                    }
                    
            return l;
                }
                
                
            public static boolean Judge(BigInteger x)
                {
                    BigInteger tem
            =new BigInteger("0");
                    tem
            =Sqrt(x);
                    
            if(tem.multiply(tem).compareTo(x)==0)
                        
            return true;
                    
            else
                        
            return false;
                }

                
            public static void main(String[] args)
                {
                    Scanner cin 
            = new Scanner (new BufferedInputStream(System.in));
                    String sn;
                    String se;
                    String sd;


                    
            int ca=0;
                    
            while(true)
                    {
                        ca
            ++;
                        sn
            =cin.next();
                        se
            =cin.next();
                        sd
            =cin.next();

                        BigInteger n
            =new BigInteger(sn);
                        BigInteger e
            =new BigInteger(se);
                        BigInteger d
            =new BigInteger(sd);

                        
            if(n.compareTo(BigInteger.ZERO)==0 && e.compareTo(BigInteger.ZERO)==0 &&d.compareTo(BigInteger.ZERO)==0)
                            
            break;

                        
            for(int i=1;i<=100;i++)
                        {
                            BigInteger t
            =e.multiply(d).subtract(BigInteger.ONE).divide(BigInteger.valueOf(i));
                            BigInteger t2
            = t.subtract(n).subtract(BigInteger.ONE).pow(2).subtract(BigInteger.valueOf(4).multiply(n));
                            
            if(Judge( t2 )==true)
                            {
                                t2
            =Sqrt(t2);
                               
            // System.out.println(t2);
                                BigInteger p=n.subtract(t).add(BigInteger.ONE).add(t2).divide(BigInteger.valueOf(2));
                                BigInteger q
            =n.subtract(t).add(BigInteger.ONE).subtract(t2).divide(BigInteger.valueOf(2));
                                
            if(q.compareTo(p)<0)
                                {
                                    BigInteger mm
            =q;
                                    q
            =p;
                                    p
            =mm;
                                }


                                System.out.println(
            "Case #"+ca+":"+" "+p+" "+q);
                                
            break;



                            }

                        }


                    }




                }
            }


            posted on 2010-11-12 17:23 abilitytao 閱讀(442) 評論(0)  編輯 收藏 引用


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


            色综合久久久久综合体桃花网| 国产L精品国产亚洲区久久| 亚洲国产高清精品线久久| 久久综合亚洲色一区二区三区| 久久人妻少妇嫩草AV蜜桃| 久久久久亚洲AV片无码下载蜜桃| 久久精品aⅴ无码中文字字幕不卡| 久久久精品免费国产四虎| 午夜精品久久影院蜜桃| 狠狠色丁香婷婷综合久久来 | 2021久久精品免费观看| 国产91色综合久久免费| 青青热久久国产久精品| 亚洲AV日韩精品久久久久久久| 日本三级久久网| 亚洲香蕉网久久综合影视| 99精品久久久久久久婷婷| 少妇内射兰兰久久| 一本大道久久东京热无码AV| 久久se精品一区二区| 狠狠色综合网站久久久久久久高清 | 久久午夜福利无码1000合集| 狠狠色丁香婷综合久久| 思思久久99热只有频精品66| 久久精品这里热有精品| 久久夜色精品国产噜噜亚洲AV| 99久久久久| 色偷偷888欧美精品久久久| 久久久久亚洲AV无码永不| 精品国产日韩久久亚洲| 看全色黄大色大片免费久久久| 国产精品青草久久久久婷婷| 亚洲中文久久精品无码| 99久久国产宗和精品1上映| 久久综合视频网站| 亚洲а∨天堂久久精品9966| 精品一区二区久久| 国产一级做a爰片久久毛片| 2021久久国自产拍精品| 国产精品美女久久久久久2018| 人妻丰满AV无码久久不卡|