• <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>
            隨筆 - 68  文章 - 57  trackbacks - 0
            <2010年4月>
            28293031123
            45678910
            11121314151617
            18192021222324
            2526272829301
            2345678

            常用鏈接

            留言簿(8)

            隨筆分類(74)

            隨筆檔案(68)

            搜索

            •  

            最新評(píng)論

            閱讀排行榜

            評(píng)論排行榜

            最后化成c * x = b - a mod (2 ^ k),解這個(gè)模線性方程,輸出最小正解即可。
            寫(xiě)程序的時(shí)候有了一個(gè)誤區(qū),以為如果b - a是負(fù)的,把它化成正的話那么輸出的時(shí)候就可以直接模2 ^ k,不用再考慮是負(fù)的情況了。但是忽略了x可能為負(fù)的情況,所以WA了很多次。其實(shí)根本不需考慮b - a的正負(fù)性,最后輸出的時(shí)候加2 ^ k再模2 ^ k就行了。
            還有一個(gè)是輸出最小解,因?yàn)樽詈蟮乃薪饽 / d同余,因此直接模n / d即可。
            #include <cstdio>

            //ax + by = gcd(a, b)
            long long extended_gcd(long long a, long long b, long long &x, long long &y)
            {
                
            long long ret, tmp;
                
            if (!b)
                
            {
                    x 
            = 1, y = 0;
                    
            return a;
                }

                ret 
            = extended_gcd(b, a % b, x, y);
                tmp 
            = x;
                x 
            = y;
                y 
            = tmp - a / b * y;
                
            return ret;
            }


            //ax = b mod n
            long long modular_linear_equation(long long a, long long b, long long n)
            {
                
            long long x, y, e;
                
            long long d = extended_gcd(a, n, x, y);
                
            if (b % d)  return -1;
                e 
            = b / d * x % n + n;
                
            return e % (n / d);
            }


            int main()
            {
                
            long long a, b, c, ans;
                
            int k;

                
            while (scanf("%lld %lld %lld %d"&a, &b, &c, &k) == 4)
                
            {
                    
            if (a == 0 && b == 0 && c == 0 && k == 0)
                        
            break;
                    ans 
            = modular_linear_equation(c, b - a, 1LL << k);
                    
            if (ans == -1)
                        puts(
            "FOREVER");
                    
            else
                        printf(
            "%lld\n", ans);
                }


                
            return 0;
            }

            posted on 2009-03-17 18:53 sdfond 閱讀(1523) 評(píng)論(2)  編輯 收藏 引用 所屬分類: Algorithm - Number Theory

            FeedBack:
            # re: POJ 2115 —— 模線性方程 2009-10-12 20:57 xiaoe
            。。。隨便搜個(gè)居然是你的  回復(fù)  更多評(píng)論
              
            # re: POJ 2115 —— 模線性方程 2009-10-13 10:42 sdfond
            @xiaoe
            呵呵 以前隨便寫(xiě)的~~
            一看師兄用的就是google,用百度搜不到我這里:-)  回復(fù)  更多評(píng)論
              
            久久99精品久久久久子伦| 久久婷婷人人澡人人| 亚洲va久久久噜噜噜久久天堂| 伊人情人综合成人久久网小说 | 亚洲伊人久久精品影院| 久久精品天天中文字幕人妻| 91精品国产91久久久久久蜜臀| 久久精品国产亚洲精品| 久久人人爽人人爽人人AV东京热| 青青青伊人色综合久久| 久久精品人人做人人爽电影| 大美女久久久久久j久久| 亚洲色大成网站www久久九| 久久99精品久久久久久秒播| 亚洲午夜久久久久久久久电影网| 国产高潮国产高潮久久久91| 久久亚洲中文字幕精品有坂深雪| 国产伊人久久| 99久久无码一区人妻| 久久久无码精品亚洲日韩蜜臀浪潮| 国产精品美女久久久久av爽| 午夜精品久久久久久毛片| 久久久久久一区国产精品| 国产精品成人久久久久三级午夜电影| 狠狠综合久久综合88亚洲| 中文国产成人精品久久亚洲精品AⅤ无码精品| 久久亚洲国产成人精品性色| 久久99精品国产麻豆宅宅| 一本久久免费视频| 欧美精品丝袜久久久中文字幕 | 久久亚洲国产最新网站| 久久国产美女免费观看精品 | 麻豆亚洲AV永久无码精品久久| 中文字幕精品无码久久久久久3D日动漫| 久久国产高清字幕中文| 99久久久精品| 91精品国产91久久久久久青草| 66精品综合久久久久久久| 精品久久久久久99人妻| 亚洲AV伊人久久青青草原| 久久精品中文字幕一区|