青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

Why so serious? --[NKU]schindlerlee

2009年12月21日星期一.sgu499

2009年12月21日星期一.sgu499
注:此文包括線性篩法,質因子分解,dfs生成一個數的所有因子

sgu499:我想撞墻
http://www.shnenglu.com/schindlerlee/
那天arxor看我和angelclover在做,然后也在看題,這個題我還沒看,然后arxor大牛就給我說了個想法

把每個數分解素因子,然后dfs出這個數的所有因子。
對每個數進行一次此操作,最后找最大的且被訪問了兩邊以上的因子,
但是這個方法tle在test 20了。怪我當時沒細想,被大牛隨便一說就覺得這個方法很好。。。。然后。。。杯具了

上代碼:tle@20
 1 /*
 2  * SOUR:sgu Greatest Greatest Common Divisor
 3  * ALGO:因子分解
 4  * DATE: 2009年 12月 20日 星期日 19:24:49 CST
 5  * COMM:3http://www.shnenglu.com/schindlerlee/
 6  * */
 7 #include<iostream>
 8 #include<cstdio>
 9 #include<cstdlib>
10 #include<cstring>
11 #include<algorithm>
12 using namespace std;
13 typedef long long LL;
14 const int maxint = 0x7fffffff;
15 const long long max64 = 0x7fffffffffffffffll;
16 
17 const int N = 1000010;
18 int vis[N], n, is_prime[N], primes[N], top;
19 int exp[100], num[100], cnt;
20 int can[N];
21 void generate()
22 {
23     int i, j, k;
24     top = 0;
25     fill(is_prime, is_prime + N, 1);
26     for (i = 2; i <= 1000000; i++) {
27         if (is_prime[i]) {
28             primes[top++= i;
29         }
30         for (j = 0; j < top && i * primes[j] <= 1000000; j++) {
31             is_prime[i * primes[j]] = 0;
32             if (i % primes[j] == 0)
33                 break;
34         }
35     }
36     //for(i = 0;i < top;i++) {
37     //printf("%d\n",primes[i]);
38     //}
39 }
40 
41 void factor(int x)
42 {
43     //printf("factor %d\n",x);
44     cnt = 0;
45     for (int i = 0; i < top && x > 1; i++) {
46         if (x % primes[i] == 0) {
47             //printf("primes[i] = %d\n",primes[i]);
48             can[i]++;
49             num[cnt] = primes[i];
50             exp[cnt] = 0;
51             while (x % primes[i] == 0) {
52                 exp[cnt]++;
53                 x /= primes[i];
54             }
55             cnt++;
56         }
57     }
58 }
59 
60 void dfs(int x, int level)
61 {
62     if (level == cnt) {
63         //printf("dfs x= %d\n",x);
64         vis[x]++;
65         return;
66     }
67     dfs(x, level + 1);
68     for (int i = 1; i <= exp[level]; i++) {
69         x *= num[level];
70         dfs(x, level + 1);
71     }
72 }
73 
74 int main()
75 {
76     int i, j, k;
77     generate();
78     scanf("%d"&n);
79     for (i = 0; i < n; i++) {
80         scanf("%d"&k);
81         factor(k);
82         dfs(10);
83     }
84     for (i = N - 1; i >= 0; i--) {
85         if (vis[i] >= 2) {
86             printf("%d\n", i);
87             break;
88         }
89     }
90     return 0;
91 }
92 

然后比賽完google了以下,原來是水題,不予解釋了,貼代碼
 1 
 2 const int N = 1000010;
 3 int vis[N],n,m;
 4 void chkmax(int &x,int k) { if(x < k) x = k; }
 5 int main()
 6 {
 7     int i,j,k;
 8     scanf("%d",&n);
 9     for(i = 0;i < n;i++) {
10         scanf("%d",&k);
11         vis[k] ++;
12         chkmax(m,k);
13     }
14 
15     int res = 1;
16     for(i = 2;i <= m;i++) {
17         int tmp = 0;
18         for(j = i;tmp < 2 && j <= m;j += i) {
19             tmp += vis[j];
20         }
21         if(tmp >= 2) res = i;
22     }
23     printf("%d\n",res);
24
25     return 0;
26 }
27 
28 

結果第二天arxor,說他用那個方法過了。。。。。。。。。
然后我看了他的代碼,我發現原來我的因子分解是沒有優化的。。。
然后把第45行改成
    for (int i = 0; primes[i] * primes[i] <= x && i < top && x > 1; i++) {

過了。。。。。

posted on 2009-12-21 20:54 schindlerlee 閱讀(1103) 評論(0)  編輯 收藏 引用 所屬分類: 解題報告

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            欧美一级久久久| 国产三级欧美三级| 久久久久五月天| 欧美国产日韩一区二区三区| 久久激情五月婷婷| 国产精品草莓在线免费观看| 欧美国产视频在线| 狠狠色丁香婷婷综合久久片| 一区二区三欧美| 9色porny自拍视频一区二区| 鲁大师成人一区二区三区| 久久久精品一品道一区| 国产农村妇女毛片精品久久麻豆| 一本久久精品一区二区| 亚洲少妇自拍| 欧美日韩在线电影| 亚洲精品中文字幕女同| 正在播放日韩| 欧美三级电影网| 亚洲视频在线观看免费| 亚洲一区精品视频| 国产精品久久久久久久久久久久| 亚洲最新视频在线| 亚洲在线一区二区| 欧美视频中文一区二区三区在线观看| 亚洲精品一级| 久久成人精品一区二区三区| 国产精品久久久久久久久免费樱桃| 欧美在线观看天堂一区二区三区| 国产欧美日韩另类一区| 欧美激情视频给我| 欧美一区二区三区四区视频| 91久久夜色精品国产九色| 欧美一区午夜精品| 在线中文字幕一区| 亚洲啪啪91| 黄色成人av| 国产人成一区二区三区影院| 欧美精品电影| 六月丁香综合| 久久精品国产精品亚洲| 中文日韩在线视频| 亚洲激情欧美激情| 老司机一区二区| 欧美一区二区播放| 亚洲女女女同性video| 亚洲日本免费| 在线观看一区| 国产伊人精品| 国产精品日韩在线一区| 欧美精品精品一区| 免费视频一区| 久久色在线观看| 久久不射网站| 香蕉久久夜色精品| 亚洲欧美综合另类中字| 一本色道久久88精品综合| 91久久精品美女高潮| 亚洲第一综合天堂另类专| 蜜桃久久精品一区二区| 久久精品一区二区三区中文字幕| 西瓜成人精品人成网站| 午夜在线一区二区| 久久国产精品久久久| 欧美亚洲视频| 欧美在线观看网站| 久久久精品国产一区二区三区| 久久av一区二区三区漫画| 香蕉久久久久久久av网站| 午夜在线精品| 久久久综合网站| 久久手机精品视频| 蜜桃久久精品乱码一区二区| 美乳少妇欧美精品| 亚洲高清不卡在线观看| 亚洲精品欧洲| 日韩午夜中文字幕| 中文精品在线| 欧美亚洲视频| 久久精品夜色噜噜亚洲a∨| 久久精品视频在线播放| 久久综合九色欧美综合狠狠| 美女视频黄a大片欧美| 欧美黑人多人双交| 欧美图区在线视频| 国产日本欧美一区二区三区在线| 国产亚洲人成网站在线观看| 一色屋精品视频在线观看网站| 亚洲国产黄色| 一区二区电影免费观看| 欧美一区高清| 免费在线成人| 日韩视频中文| 亚洲欧美日韩另类精品一区二区三区| 欧美在线网站| 欧美福利电影网| 国产精品美女| 揄拍成人国产精品视频| 日韩亚洲成人av在线| 午夜精品一区二区三区在线播放| 久久久久久久久久久久久久一区| 欧美国产亚洲精品久久久8v| 9久re热视频在线精品| 欧美在线播放一区二区| 欧美精品1区2区| 国产一区二区电影在线观看| 亚洲免费观看高清完整版在线观看熊| 亚洲在线观看免费| 欧美刺激午夜性久久久久久久| 宅男噜噜噜66一区二区66| 久久精品人人爽| 欧美日韩视频第一区| 激情偷拍久久| 亚洲一区在线免费观看| 免费一级欧美片在线观看| 一本色道久久加勒比精品| 久久免费偷拍视频| 国产精品欧美久久| 亚洲精品日韩久久| 欧美在线在线| 亚洲欧洲一二三| 久久精品日产第一区二区三区 | 99国产精品私拍| 欧美一区在线视频| 欧美日韩一区二区精品| 一区二区视频欧美| 亚洲免费在线观看| 亚洲激情成人网| 久久久精品国产一区二区三区| 欧美三级电影大全| 亚洲美洲欧洲综合国产一区| 久久久久综合一区二区三区| 亚洲最新色图| 欧美人与性禽动交情品| 亚洲成人在线视频播放| 欧美一区二区精品在线| 亚洲精品在线观看免费| 欧美成人免费在线| 影音国产精品| 久久久久久久久久久成人| 亚洲欧美成人网| 国产精品美女久久久久av超清 | 欧美阿v一级看视频| 韩国精品久久久999| 欧美在线高清视频| 中日韩在线视频| 国产精品红桃| 亚洲特级片在线| 亚洲最新在线| 国产精品国产三级国产专播精品人| 亚洲伦理自拍| 亚洲人成小说网站色在线| 免费亚洲电影| 亚洲精品视频免费观看| 农村妇女精品| 老鸭窝91久久精品色噜噜导演| 一色屋精品视频在线观看网站| 久久免费视频这里只有精品| 久久av资源网站| 一区在线视频| 免费在线看一区| 欧美成人a∨高清免费观看| 亚洲激情视频网站| 亚洲国产欧美一区| 欧美激情一区二区三区四区| 日韩午夜三级在线| 亚洲巨乳在线| 国产精品超碰97尤物18| 欧美一区二区三区四区视频| 亚洲一区国产一区| 国产视频久久| 美女视频一区免费观看| 免费视频一区| 在线亚洲伦理| 亚洲欧美日韩精品久久亚洲区| 国产资源精品在线观看| 久久夜色精品国产亚洲aⅴ| 免费久久精品视频| 在线视频欧美日韩| 亚洲主播在线播放| 精品福利免费观看| 91久久久久久久久| 国产精品五月天| 久久综合精品一区| 欧美国产日韩一区二区在线观看| 亚洲一区影院| 久久久欧美精品sm网站| 亚洲蜜桃精久久久久久久| 亚洲自拍电影| 亚洲激情电影中文字幕| 亚洲精品乱码久久久久久| 国产精品久久一卡二卡| 蜜臀99久久精品久久久久久软件| 欧美激情视频免费观看| 欧美一区二区在线看| 你懂的网址国产 欧美| 亚洲欧美综合| 美国成人直播| 亚洲在线视频网站| 美女精品一区|