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

            Dain

            寫出一個可以工作的程序并不夠

            統計

            留言簿(3)

            積分與排名

            良師益友

            閱讀排行榜

            評論排行榜

            列出所有9位數,它的前n位能被n整除

            最簡單的是窮舉,不過那可要O(9*109),不可取 

            #include <iostream>
            #include 
            <vector>
            #include 
            <algorithm>

            using namespace std;

            vector
            <int> fun(int n)
            {
                vector
            <int> last,all;
                
            int i,j,k;
                
            for(i = 1;i < 10;++i)
                    all.push_back(i);

                
            if(n == 1)
                    
            return all;

                
            int size;
                
            int num;
                
            for(i = 2;i <= n;++i)
                
            {
                    last 
            = all;
                    all.clear();
                    size 
            = (int)last.size();
                    
            for(j = 0;j < size;++j)
                    
            {
                        
            for(k = 0;k < 10;++k)
                        
            {
                            num 
            = last[j] * 10 + k;
                            
            if(num % i == 0)
                                all.push_back(num);
                        }

                    }

                    last.clear();
                }


                
            return all;
            }

            posted on 2007-04-16 17:29 Dain 閱讀(1126) 評論(5)  編輯 收藏 引用 所屬分類: 算法 、筆記

            評論

            # re: 列出所有9位數,它的前n位能被n整除 2007-04-17 00:16 踏雪赤兔

            #include<ctime>
            #include<iostream>
            using namespace std;
            int cnt=0;
            void dfs(int s,int i){
            if(i>9){
            cout<<s<<endl;
            cnt++;
            return;
            }
            s*=10;
            int m=s%i;
            if(m!=0) m=i-m;
            for(; m<10; m+=i) dfs(s+m,i+1);
            }
            int main(){
            for(int j=0; j<10000;++j){
            cnt=0;
            for(int i=1; i<10; ++i) dfs(i,2);
            // cout<<cnt<<endl;
            }
            cout<<clock();
            return 0;
            }
            答案有2492個,不計輸出用時約0.00058秒  回復  更多評論   

            # re: 列出所有9位數,它的前n位能被n整除 2007-04-17 09:04 萬連文

            組合數學內容,早知道它很有用,可是還是忘記的差不多了,唉...  回復  更多評論   

            # re: 列出所有9位數,它的前n位能被n整除 2007-04-19 17:17 wzqxp2002

            我做出來是2227個  回復  更多評論   

            # re: 列出所有9位數,它的前n位能被n整除 2007-04-19 19:52 wzqxp2002

            是我看錯了,是2492個  回復  更多評論   

            # re: 列出所有9位數,它的前n位能被n整除[未登錄] 2007-04-21 21:12 Dain

            看下你的算法
            @wzqxp2002
              回復  更多評論   

            久久久久97国产精华液好用吗| 国产成人精品久久亚洲高清不卡 | 亚洲国产二区三区久久| 国内精品久久久久久久97牛牛 | 一本色道久久99一综合| 波多野结衣AV无码久久一区| 天天躁日日躁狠狠久久| 久久婷婷五月综合色高清| 精品国产乱码久久久久久郑州公司| 久久水蜜桃亚洲av无码精品麻豆| 伊人久久精品无码av一区| 国内精品久久九九国产精品| 久久99精品久久久久久水蜜桃| 亚洲国产成人精品女人久久久 | 欧美日韩中文字幕久久久不卡| 国产精品久久久久免费a∨| 国产精品免费久久久久影院 | 漂亮人妻被黑人久久精品| 热RE99久久精品国产66热| 99久久精品免费观看国产| 亚洲伊人久久精品影院| 久久国产视频99电影| 国内精品伊人久久久久网站| 蜜臀久久99精品久久久久久小说| 狠狠色伊人久久精品综合网| 超级碰久久免费公开视频| 国产婷婷成人久久Av免费高清 | 国产午夜精品久久久久九九电影| 亚洲国产成人久久精品影视 | 久久乐国产综合亚洲精品| 国产精品成人久久久| 久久久亚洲欧洲日产国码二区| 国产精品久久久久蜜芽| 伊人久久精品无码av一区| 青青草原精品99久久精品66| 久久久久亚洲av无码专区 | 一级a性色生活片久久无少妇一级婬片免费放 | 久久婷婷午色综合夜啪| 久久午夜伦鲁片免费无码| 国产成人久久777777| 色综合久久综合中文综合网|