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

糯米

TI DaVinci, gstreamer, ffmpeg
隨筆 - 167, 文章 - 0, 評論 - 47, 引用 - 0
數(shù)據(jù)加載中……

POJ 2132 Cow Math 二分

思路:
首先每條路徑的值都可以分解一下質(zhì)因數(shù),就可以表示為多個(gè)質(zhì)數(shù)的冪相乘的形式,
 比如 2^6 * 3^8 * 17^22 * 23^1。

三個(gè)數(shù)字a, b, c求最大公約數(shù),分解完質(zhì)因數(shù)后:
如果a擁有2^8,b擁有2^10,c擁有2^4。那最大公約數(shù)必然擁有2^4,取最小的一個(gè)。
對于每個(gè)質(zhì)數(shù) 2, 3, 5, 7。。都是這個(gè)道理。

如果是求最小公倍數(shù),在剛剛的例子里,就是取最大的一個(gè)了。

在點(diǎn)之間行走的過程,可以這樣來看。在點(diǎn)1的時(shí)候GCF的值是所有質(zhì)數(shù)的最大次冪的乘積。
GCF的值必定是越走越小。
每經(jīng)過一條路徑,CGF各個(gè)質(zhì)因數(shù)的冪都必須小于等于路徑的對應(yīng)的值。
就好比路徑就只能容納這么大的流量。然后到達(dá)點(diǎn)2的時(shí)候,看看哪條路徑的流量最大。
看起來像最大流問題,但不是最大流問題。

我們沒辦法遍歷一次圖,就求出哪條路徑的流量最大。
但由于路徑的權(quán)值最大才2000,質(zhì)因數(shù)的冪最大也只有11(2^11 = 2048),大不了每個(gè)冪都試一次。
用二分法就可以了。

對于每一個(gè)質(zhì)數(shù),求到達(dá)點(diǎn)2 的時(shí)候的最大的冪。
最后再乘起來,就是答案了。
可見這種方法還是很巧妙的,效率也很高,0ms AC。

注意:
不需要高精度。但需要用__int64來保存答案。

#include <stdio.h>

#define MAX_W 2048
#define MAX_N 32 

int N, visit[MAX_N], map[MAX_N][MAX_N], tm;
int prime[MAX_W], prime_cnt, max_cnt[MAX_W];

int dfs(int idx, int val, int cnt)
{
    
int i, j, k;

    
if (idx == 2)
        
return 1;

    visit[idx] 
= tm;
    
for (i = 1; i <= N; i++{
        
if (visit[i] == tm)
            
continue;
        j 
= map[idx][i];
        
for (k = 0; j && !(j % val); k++)
            j 
/= val;
        
if (k < cnt)
            
continue;
        
if (dfs(i, val, cnt))
            
return 1;
    }


    
return 0;
}


__inline 
int calc(int val, int r)
{
    
int l, m;

    l 
= 0;
    
while (l <= r) {
        m 
= (l + r) / 2;
        tm
++;
        
if (dfs(1, val, m))
            l 
= m + 1;
        
else
            r 
= m - 1;
    }


    
return r;
}


int main()
{
    
int i, j, val, p, cnt;
    __int64 r;

    freopen(
"e:\\test\\in.txt""r", stdin);

    prime[prime_cnt
++= 2;
    
for (i = 3; i < MAX_W; i++{
        
for (j = 0; j < prime_cnt && (i % prime[j]); j++);
        
if (j == prime_cnt)
            prime[prime_cnt
++= i;
    }

    
    scanf(
"%d"&N);
    
for (i = 1; i <= N; i++)
        
for (j = 1; j <= N; j++)
            scanf(
"%d"&map[i][j]);
    
    
for (i = 2; i <= N; i++{
        val 
= map[1][i];
        
for (j = 0; j < prime_cnt && val >= 1; j++{
            p 
= prime[j];
            
for (cnt = 0!(val % p); cnt++)
                val 
/= p;
            
if (cnt > max_cnt[j])
                max_cnt[j] 
= cnt;
        }

    }

    
    
for (i = 0; i < prime_cnt; i++{
        
if (!max_cnt[i])
            
continue;
        max_cnt[i] 
= calc(prime[i], max_cnt[i]);
    }


    r 
= 1;
    
for (i = 0; i < prime_cnt; i++{
        
if (!max_cnt[i])
            
continue;
        
for (cnt = 0; cnt < max_cnt[i]; cnt++)
            r 
*= prime[i];
    }

    printf(
"%I64d\n", r);

    
return 0;
}

posted on 2010-03-14 14:37 糯米 閱讀(637) 評論(1)  編輯 收藏 引用 所屬分類: POJ

評論

# re: POJ 2132 Cow Math 二分[未登錄]  回復(fù)  更多評論   

POJ 2132 Cow Math 二分

思路:
首先每條路徑的值都可以分解一下質(zhì)因數(shù),就可以表示為多個(gè)質(zhì)數(shù)的冪相乘的形式,
比如 2^6 * 3^8 * 17^22 * 23^1。

三個(gè)數(shù)字a, b, c求最大公約數(shù),分解完質(zhì)因數(shù)后:
如果a擁有2^8,b擁有2^10,c擁有2^4。那最大公約數(shù)必然擁有2^4,取最小的一個(gè)。
對于每個(gè)質(zhì)數(shù) 2, 3, 5, 7。。都是這個(gè)道理。

如果是求最小公倍數(shù),在剛剛的例子里,就是取最大的一個(gè)了。

在點(diǎn)之間行走的過程,可以這樣來看。在點(diǎn)1的時(shí)候GCF的值是所有質(zhì)數(shù)的最大次冪的乘積。
GCF的值必定是越走越小。
每經(jīng)過一條路徑,CGF各個(gè)質(zhì)因數(shù)的冪都必須小于等于路徑的對應(yīng)的值。
就好比路徑就只能容納這么大的流量。然后到達(dá)點(diǎn)2的時(shí)候,看看哪條路徑的流量最大。
看起來像最大流問題,但不是最大流問題。

我們沒辦法遍歷一次圖,就求出哪條路徑的流量最大。
但由于路徑的權(quán)值最大才2000,質(zhì)因數(shù)的冪最大也只有11(2^11 = 2048),大不了每個(gè)冪都試一次。
用二分法就可以了。

對于每一個(gè)質(zhì)數(shù),求到達(dá)點(diǎn)2 的時(shí)候的最大的冪。
最后再乘起來,就是答案了。
可見這種方法還是很巧妙的,效率也很高,0ms AC。

注意:
不需要高精度。但需要用__int64來保存答案。


#include <stdio.h>

#define MAX_W 2048
#define MAX_N 32

int N, visit[MAX_N], map[MAX_N][MAX_N], tm;
int prime[MAX_W], prime_cnt, max_cnt[MAX_W];

int dfs(int idx, int val, int cnt)
{
int i, j, k;

if (idx == 2)
return 1;

visit[idx] = tm;
for (i = 1; i <= N; i++) {
if (visit[i] == tm)
continue;
j = map[idx][i];
for (k = 0; j && !(j % val); k++)
j /= val;
if (k < cnt)
continue;
if (dfs(i, val, cnt))
return 1;
}

return 0;
}

__inline int calc(int val, int r)
{
int l, m;

l = 0;
while (l <= r) {
m = (l + r) / 2;
tm++;
if (dfs(1, val, m))
l = m + 1;
else
r = m - 1;
}

return r;
}

int main()
{
int i, j, val, p, cnt;
__int64 r;

freopen("e:\\test\\in.txt", "r", stdin);

prime[prime_cnt++] = 2;
for (i = 3; i < MAX_W; i++) {
for (j = 0; j < prime_cnt && (i % prime[j]); j++);
if (j == prime_cnt)
prime[prime_cnt++] = i;
}

scanf("%d", &N);
for (i = 1; i <= N; i++)
for (j = 1; j <= N; j++)
scanf("%d", &map[i][j]);

for (i = 2; i <= N; i++) {
val = map[1][i];
for (j = 0; j < prime_cnt && val >= 1; j++) {
p = prime[j];
for (cnt = 0; !(val % p); cnt++)
val /= p;
if (cnt > max_cnt[j])
max_cnt[j] = cnt;
}
}

for (i = 0; i < prime_cnt; i++) {
if (!max_cnt[i])
continue;
max_cnt[i] = calc(prime[i], max_cnt[i]);
}

r = 1;
for (i = 0; i < prime_cnt; i++) {
if (!max_cnt[i])
continue;
for (cnt = 0; cnt < max_cnt[i]; cnt++)
r *= prime[i];
}
printf("%I64d\n", r);

return 0;
}
2014-08-07 14:52 | 糯米
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            亚洲欧美日韩区| 国产精品视频内| 亚洲人成在线免费观看| 久久国产精品一区二区三区四区| 黄色成人av网站| 1000部国产精品成人观看| 黄色成人在线网址| 日韩视频在线一区二区| 一区二区三区 在线观看视频| 亚洲每日在线| 久久国产精品亚洲77777| 久久久久久久久久久成人| 欧美成人免费网站| 日韩网站在线| 久久久久久亚洲精品杨幂换脸| 久久久噜噜噜久久| 欧美特黄a级高清免费大片a级| 国产精品手机在线| 日韩网站在线观看| 久久久久99精品国产片| 亚洲国产日本| 欧美一区在线直播| 欧美午夜久久久| 亚洲第一精品电影| 亚洲欧美日韩精品久久| 欧美高清免费| 久久精品理论片| 国产精品日韩欧美一区二区三区| 日韩视频在线一区二区三区| 亚洲一区在线观看免费观看电影高清| 亚洲欧美怡红院| 欧美日韩精品欧美日韩精品| 亚洲大胆人体视频| 你懂的视频一区二区| 久久国产精品一区二区三区| 国产精品久久看| 亚洲欧美一区二区三区久久| 亚洲欧洲一区二区三区久久| 美日韩精品免费| 亚洲乱码国产乱码精品精可以看 | 午夜欧美大尺度福利影院在线看 | 日韩视频在线一区二区| 免费久久久一本精品久久区| 亚洲经典在线| 日韩亚洲一区二区| 国产精品亚洲人在线观看| 欧美永久精品| 久久久久综合一区二区三区| 在线播放亚洲一区| 亚洲国产精品一区制服丝袜| 欧美丰满少妇xxxbbb| 亚洲欧美中文字幕| 久久一区二区精品| 亚洲欧美成人一区二区在线电影| 亚洲综合色丁香婷婷六月图片| 国产午夜精品一区二区三区欧美 | 欧美日韩三区| 亚洲另类视频| 亚洲欧美偷拍卡通变态| 在线观看国产日韩| 亚洲一区二区免费| 亚洲精品国产日韩| 欧美一区二区视频97| 99精品福利视频| 免费成人在线观看视频| 久久gogo国模裸体人体| 欧美激情精品久久久久久变态 | 欧美日韩高清区| 久久久7777| 国产精品日韩欧美一区二区三区 | 亚洲激情不卡| 狠狠做深爱婷婷久久综合一区| 亚洲最新视频在线| 亚洲精品偷拍| 欧美黄色影院| 久久久国际精品| 国产精品一卡二| 亚洲欧美激情四射在线日 | 亚洲自啪免费| 中文av一区二区| 国产精品区一区二区三| 亚洲视频精品| 久久精品夜色噜噜亚洲a∨ | 亚洲自拍都市欧美小说| 欧美日韩伦理在线免费| 一本色道久久88综合日韩精品| 99www免费人成精品| 欧美三级日本三级少妇99| 99国产精品私拍| 久久国产精品网站| 日韩一级在线观看| 国产精品伊人日日| 老司机成人在线视频| 亚洲精品在线视频观看| 午夜精品影院| 亚洲电影在线免费观看| 欧美午夜一区二区| 久久夜色精品国产亚洲aⅴ| 亚洲福利精品| 久久久国产精品一区二区中文| 亚洲国产成人av| 欧美性色aⅴ视频一区日韩精品| 亚洲欧美日韩成人高清在线一区| 美女精品自拍一二三四| 亚洲在线观看视频| av成人免费| 亚洲日本欧美在线| 精品999网站| 国产在线麻豆精品观看| 精品va天堂亚洲国产| 亚洲精品在线二区| 久久激情视频| 欧美激情中文字幕在线| 99re热这里只有精品免费视频| 亚洲午夜av在线| 久久久久一区二区三区四区| 欧美精品免费视频| 伊人婷婷久久| 午夜精品免费在线| 亚洲欧美偷拍卡通变态| 亚洲直播在线一区| 在线国产精品一区| 国产综合色产在线精品| 国内精品久久久久影院色| 国产一区二区三区久久悠悠色av | 国产区日韩欧美| 国产亚洲aⅴaaaaaa毛片| 国产欧美精品在线| 亚洲福利在线观看| 亚洲视频精选在线| 久久久久久电影| 亚洲福利视频一区二区| 夜夜爽www精品| 久久国产精品99国产精| 欧美电影在线| 国外视频精品毛片| 中国成人亚色综合网站| 久久精品五月| 一本一本久久a久久精品综合妖精| 亚洲欧美另类在线| 欧美精品一区在线发布| 黄色一区二区在线| 欧美影院久久久| 亚洲狼人综合| 欧美成人激情视频免费观看| 国产精品视频专区| 亚洲性xxxx| 亚洲自拍另类| 国产日韩精品在线播放| 亚洲欧美日韩精品在线| 亚洲区一区二区三区| 欧美电影在线观看完整版| 国产一区二区三区久久| 亚洲天堂成人在线观看| 亚洲精品黄色| 欧美理论在线播放| 日韩亚洲欧美成人| 日韩亚洲国产欧美| 欧美性jizz18性欧美| 亚洲无限av看| 亚洲欧美日韩精品一区二区 | 欧美 日韩 国产精品免费观看| 亚洲性感美女99在线| 国产欧美一区二区精品性| 久久精品一二三区| 久久视频一区二区| 亚洲免费av网站| 亚洲一区影音先锋| 一区二区亚洲精品国产| 亚洲电影免费在线观看| 欧美精品aa| 久久久久久夜| 欧美日韩不卡合集视频| 欧美亚洲在线观看| 欧美国产日产韩国视频| 欧美亚洲三区| 欧美激情日韩| 毛片基地黄久久久久久天堂| 欧美黄在线观看| 噜噜爱69成人精品| 国产精品美女久久福利网站| 老司机67194精品线观看| 欧美亚州一区二区三区| 91久久久在线| 亚洲经典三级| 裸体一区二区三区| 免费91麻豆精品国产自产在线观看| 欧美日韩大片一区二区三区| 欧美.www| 亚洲国产第一| 免费久久99精品国产| 麻豆成人在线播放| 亚洲福利在线视频| 久久久噜噜噜久久| 嫩草成人www欧美| 影音先锋亚洲视频| 欧美日韩免费观看一区=区三区| 欧美激情欧美狂野欧美精品| 亚洲国产一区二区三区高清| 美女在线一区二区|