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

            poj 2282 The Counting Problem 3252 round numbers

            兩個(gè)都是麻煩的計(jì)數(shù)問(wèn)題,只不過(guò)一個(gè)是二進(jìn)制,另一個(gè)似乎更貼近十進(jìn)制的現(xiàn)實(shí)世界.不過(guò)計(jì)算機(jī)里,還是二進(jìn)制感覺(jué)能跑得更快一些,移位總比乘十來(lái)得更快一些.
            計(jì)數(shù)從0-n的每一位的數(shù)字個(gè)數(shù),先計(jì)數(shù)位數(shù)小于n的位數(shù)的數(shù)字個(gè)數(shù),再?gòu)母呶坏降臀灰来窝h(huán)累加計(jì)數(shù)和n位數(shù)相同且小于n的數(shù)的各位數(shù)字.考慮的情形很多,有一點(diǎn)考慮不到就很難得到正確答案.

            /*Source Code

            Problem: 2282  User: y09shendazhi 
            Memory: 220K  Time: 16MS 
            Language: C++  Result: Accepted 

            Source Code 
            */

            #include 
            <iostream>
            using namespace std;

            int ans[15];//answer
            int pow(int a,int b)
            {
                
            int an=1;
                
            for(int i=0;i<b;i++)
                    an
            *=a;
                
            return an;
            }

            void solve(int n)
            {
                
            int i,j,k;
                memset(ans,
            0,sizeof(ans));
                
            if(n<10)
                
            {
                    
            for(i=1;i<=n;i++)
                        ans[i]
            =1;
                    
            return ;
                }

                
                
            int digit[20]={0};
                
            int dec=0;//decimal of n
                int temp=0;
                temp
            =n;
                
            while(temp)
                
            {
                    digit[dec
            ++]=temp%10;
                    temp
            /=10;
                }

                temp
            =pow(10,dec-1);

                
            for(i=1;i<10;i++)//位數(shù)小于n的
                    ans[i]+=(dec-1)*temp/10;
                ans[
            0]+=(dec-1)*temp/10-(temp-1)/9;
                
                
            for(i=1;i<digit[dec-1];i++)//最高位是  1~最高位
                {
                    ans[i]
            +=temp;
                    
            for(k=0;k<10;k++)
                        ans[k]
            +=(dec-1)*temp/10;
                }

                temp
            /=10;
                
            for(i=dec-2;i>=0;i--)
                
            {
                    
            for(j=0;j<digit[i];j++)
                    
            {
                        
            for(k=dec-1;k>i;k--)
                            ans[digit[k]]
            +=temp;
                        ans[j]
            +=temp;
                        
            for(k=0;k<10;k++)
                            ans[k]
            +=i*temp/10;
                    }

                    temp
            /=10;
                }

                
            for(i=0;i<dec;i++)
                    ans[digit[i]]
            ++;
            }

            int main(int argc, char *argv[])
            {
                
            int n,m;
                
            int ans1[15]={0};
                
            int temp=0;
                
            while(cin>>n>>m)
                
            {
                    
            if(n==0 && m==0)
                        
            break;
                    
            if(n>m)
                    
            {
                        temp
            =n;
                        n
            =m;
                        m
            =temp;
                    }

                    solve(n
            -1);
                    memcpy(ans1,ans,
            sizeof(ans));
                    solve(m);
                    
            for(int i=0;i<9;i++)
                        cout
            <<ans[i]-ans1[i]<<' ';
                    cout
            <<ans[9]-ans1[9]<<endl;
                }

                
                
            return 0;
            }


            /*Source Code

            Problem: 3252  User: y09shendazhi 
            Memory: 136K  Time: 0MS 
            Language: C++  Result: Accepted 

            Source Code 
            */

            #include 
            <iostream>
            using namespace std;

            // /n\
            // | |
            // \m/
            __int64 com(__int64 n ,__int64 m)
            {
                
            if(n<m)
                    
            return 0;
                __int64 result
            =1;
                m
            =m<n-m?m:n-m;
                
            for(__int64 i=1;i<=m;i++)
                    result
            =(result*(n-m+i))/i;    
                
            return result;
            }


            __int64 sumCom(__int64 n,__int64 m)
            {
                
            if(n==0 && m>=0)
                    
            return 1;
                
            if(m>n)
                    m
            =n;
                
            if(m<0)
                    
            return 0;
                __int64 ans
            =0;
                
            for(__int64 i=0;i<=m;i++)
                
            {
                    ans
            +=com(n,i);
                }

                
            return ans;
            }


            __int64 solve(__int64 n)
            {
                
            if(n==0 || n==1)
                    
            return 0;

                __int64 ans
            =0;
                __int64 dec
            =0;//二進(jìn)制位數(shù)
                __int64 temp=n;
                
            while(temp)
                
            {
                    dec
            ++;
                    temp
            >>=1;
                }

                temp
            =1;
                temp
            <<=dec-1;

                __int64 one
            =0;
                
            for(__int64 j=1;j<dec;j++)
                        ans
            +=sumCom(j-1,j/2-1);
                temp
            >>=1;
                one
            ++;
                
            for(__int64 i=dec-1;i>0;i--)
                
            {
                    
            if(temp&n)
                    
            {
                        ans
            +=sumCom(i-1,dec/2-one);
                        one
            ++;
                    }

                    temp
            >>=1;
                }

                
            if(one<=dec/2)
                    ans
            ++;
                
            return ans;
            }

            int main()
            {
                __int64 S,F;
            scanf(
            "%I64d%I64d",&S,&F);
                
            {
                    
            if(S==0)
                        printf(
            "%I64d\n",solve(F));
                    
            else
                        printf(
            "%I64d\n",solve(F)-solve(S-1));

                }

                
            return 0;
            }


            posted on 2010-08-20 17:22 若余 閱讀(420) 評(píng)論(0)  編輯 收藏 引用


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


            導(dǎo)航

            <2010年8月>
            25262728293031
            1234567
            891011121314
            15161718192021
            22232425262728
            2930311234

            統(tǒng)計(jì)

            常用鏈接

            留言簿

            隨筆檔案(16)

            搜索

            最新隨筆

            最新評(píng)論

            評(píng)論排行榜

            国产精品久久久久国产A级| 无码AV中文字幕久久专区| 女人香蕉久久**毛片精品| 狠狠色丁香久久婷婷综| 国产精品久久久久乳精品爆 | 精品国产热久久久福利| 久久亚洲AV无码西西人体| 国内高清久久久久久| 国产精品久久久久久一区二区三区| 伊人久久精品线影院| 色综合久久88色综合天天 | 久久婷婷五月综合97色一本一本 | 性高湖久久久久久久久| 国产香蕉97碰碰久久人人| 久久精品免费一区二区| 99久久国产亚洲高清观看2024 | 综合网日日天干夜夜久久| 国产麻豆精品久久一二三| 亚洲精品无码久久久| 久久精品国产亚洲综合色| 亚洲国产视频久久| 日韩精品久久久久久| 午夜不卡久久精品无码免费| 亚洲第一永久AV网站久久精品男人的天堂AV | 免费精品久久久久久中文字幕| 精品国产一区二区三区久久久狼 | 精品无码人妻久久久久久| 久久综合给合久久狠狠狠97色69 | 狠狠色狠狠色综合久久| 青青草原综合久久大伊人导航| 色综合久久精品中文字幕首页 | 久久精品国产亚洲AV香蕉| 亚洲精品无码久久毛片| 国产精品综合久久第一页| 中文字幕成人精品久久不卡| 久久99精品国产麻豆| 国产成人精品三上悠亚久久| 久久精品国产免费观看三人同眠| 中文成人无码精品久久久不卡| 性做久久久久久久久老女人| 欧美久久久久久午夜精品|