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

oyjpArt ACM/ICPC算法程序設(shè)計(jì)空間

// I am new in programming, welcome to my blog
I am oyjpart(alpc12, 四城)
posts - 224, comments - 694, trackbacks - 0, articles - 6

基本參數(shù)搜索

Posted on 2008-06-03 15:45 oyjpart 閱讀(3159) 評論(14)  編輯 收藏 引用 所屬分類: ACM/ICPC或其他比賽

上次百度之星第三題竟然不會做,很是慚愧啊,腦袋生銹了。

后來從HUST上面找了道類似的題目,AC了。


The perfect hamilton path

Time Limit: 5 Sec  Memory Limit: 128 MB
Submissions: 72  Solved: 16

Description

There are N(2 <= N <= 13) cities and M bidirectional roads among the cities. There exist at most one road between any pair of the cities. Along every road, there are G pretty girls and B pretty boys(1 <= G,B <= 1000).
You want to visit every city exactly once, and you can start from any city you want to. The degree of satisfaction is the ratio of the number of the pretty girls to the number of the pretty boys. You want to know the highest degree of satisfation.

Input

There are multiply test cases.
First line: two integers N, M;
The following M lines: every line with four integers i, j, G, B, response that there is a road between i and j with G and B.

Output

The highest degree of the satisfation, rounded to the third place after the decimal point.

Sample Input

3 3
1 2 5 3
2 3 7 4
3 1 13 11

Sample Output

1.714

HINT

Source

dupeng


題目的意思是找到一個(gè)sigma(G)/sigma(B)最大的hamilton回路。
典型的參數(shù)搜索。二分或者迭代答案就可以了。

Solution:

#include <stdio.h>
#include 
<queue>
#include 
<cmath>
using namespace std;

const double EPS = 1e-4;
const int N = 15;
const int M = N * N;

#define Max(a, b) (a
>b?a:b)

inline 
int dblcmp(double a, double b) {
    
if(fabs(a-b) < EPS) return 0;
    
return a < b ? -1 : 1;
}

struct Node 
{
    
int x, mask;
    
double s;
    Node() {}
    Node(
int mm, int xx, double ss) {
        x 
= xx;
        mask 
= mm;
        s 
= ss;
    }
};

int n, m;

double adj[N][N];
int X[M], Y[M], G[M], B[M];

double dp[1<<N][N];

double go(double ans) {
    
int i, j;
    
for(i = 0; i < n; ++i) {
        adj[i][i] 
= 0;
        
for(j = i+1; j < n; ++j) {
            adj[i][j] 
= adj[j][i] = -10e300;
        }
    }
    
for(i = 0; i < m; ++i) {
        adj[X[i]
-1][Y[i]-1= G[i]-ans * B[i];
        adj[Y[i]
-1][X[i]-1= adj[X[i]-1][Y[i]-1];
    }

    
for(i = 0; i < (1<<n); ++i) {
        
for(j = 0; j < n; ++j)
            dp[i][j] 
= -10e100;
    }
    queue
<Node> Q;
    
for(i = 0; i < n; ++i) {
        Q.push(Node(
1<<i, i, 0.0));
        dp[
1<<i][i] = 0;
    }
    
while(Q.size()) {
        
int f = Q.front().mask, x = Q.front().x;
        
double s = Q.front().s;
        
double& d = dp[f][x];
        Q.pop();
        
if(s < d) continue;
        
for(i = 0; i < n; ++i) if((f&(1<<i)) == 0) {
            
if(dp[f|1<<i][i] < s + adj[x][i]) {
                dp[f
|1<<i][i] = s + adj[x][i];
                Q.push(Node(f
|1<<i, i, s + adj[x][i]));
            }
        }
    }

    
double max = -10e100;
    
for(i = 0; i < n; ++i) {
        max 
= Max(max, dp[(1<<n)-1][i]);
    }
    
return max;
}

int main()
{
    
// freopen("t.in", "r", stdin);

    
int i;
    
double ans;
    
while(scanf("%d %d"&n, &m) != EOF) {
        
double min = 2000, max = 0;
        
for(i = 0; i < m; ++i) {
            scanf(
"%d %d %d %d"&X[i], &Y[i], &G[i], &B[i]);
            
if(B[i] < min) min = B[i];
            
if(G[i] > max) max = G[i];
        }
        
double lo = 0, hi = max/min;
        
int ok = 0;
        
for(i = 0; ; ++i) {
            
double mid = lo + (hi-lo)/2;
            
if(dblcmp((ans=go(mid)), 0.0> 0) {
                lo 
= mid;
            } 
else if(dblcmp(ans, 0.0== 0) {
                printf(
"%.3lf\n", mid);
                ok 
= 1;
                
break;
            } 
else {
                hi 
= mid;
            }
        }

        
if(!ok) { int a = 0; a = 1/a; }
    }

    
return 0;
}

 


Feedback

# re: 基本參數(shù)搜索  回復(fù)  更多評論   

2008-06-04 13:43 by w
你好,這個(gè)程序我看不懂……能講一下思路嗎?

# re: 基本參數(shù)搜索  回復(fù)  更多評論   

2008-06-04 14:56 by oyjpart
你可以參考《算法藝術(shù)與信息學(xué)競賽》303-304頁
3.地震--最有比率生成樹 一節(jié)的解答
和這個(gè)非常類似

就是2分枚舉那個(gè)答案,然后將除的表達(dá)式的權(quán) 轉(zhuǎn)化成+-*表達(dá)式的權(quán),再這個(gè)基礎(chǔ)上求目標(biāo)函數(shù)。 如果目標(biāo)函數(shù) != 0,則枚舉的答案應(yīng)該向使目標(biāo)函數(shù)更接近0的方向取值,

go函數(shù)實(shí)際求的就是最大權(quán)的hamilton回路。用的是基本的壓縮狀態(tài)廣搜。

# re: 基本參數(shù)搜索  回復(fù)  更多評論   

2008-06-04 15:02 by Surfing
我的解法

#include <stdio.h>

#define N 13

typedef struct _T_AdjNode
{
int nBoys;
int nGirls;
double dRatio;
}TAdjNode;

TAdjNode g_AdjNode[N][N];
int g_Path[2][N];
int g_PathIndex[2] = {0};
double g_dRatio[2] = {0.0};
int nCities, nRoads;

int FindNextNode(int nPathIndex, int nLine)
{
double dRatio = 0;
int nNode = 0;
int i = 0;
int j = 0;
bool bExist = false;

for (j = 0; j < nCities; j++)
{
for (i = 0; i < g_PathIndex[nPathIndex]; i++)
{
if (j == g_Path[nPathIndex][i])
{
bExist = true;
break;
}
}
if (bExist)
{
bExist = false;
continue;
}
if (g_AdjNode[nLine][j].dRatio > dRatio)
{
dRatio = g_AdjNode[nLine][j].dRatio;
nNode = j;
}
}

return nNode;
}

int FindPath(int nPathIndex, int nNode)
{
int nNextNode = 0;
static int nBoys = 0, nGirls = 0;

g_Path[nPathIndex][g_PathIndex[nPathIndex]] = nNode;
g_PathIndex[nPathIndex]++;
if (g_PathIndex[nPathIndex] >= nCities)
{
g_dRatio[nPathIndex] = (double)nGirls / nBoys;
return 0;
}

nNextNode = FindNextNode(nPathIndex, nNode);
nBoys += g_AdjNode[nNode][nNextNode].nBoys;
nGirls += g_AdjNode[nNode][nNextNode].nGirls;
FindPath(nPathIndex, nNextNode);

return 0;
}

int main()
{
int i,j,nGirls,nBoys;
char q = '0';
int nPathIndex = 0;

nCities = nRoads = 0;
i = j = nGirls = nBoys = 0;

printf("Input the number of cities and roads:\n");
scanf("%d %d", &nCities, &nRoads);

if (nCities < 1 || nRoads < 1)
{
return 1;
}

do
{
printf("Input the road index and the number of girls and boys sequentially : "
"from to girls boys\n");
scanf("%d %d %d %d", &i, &j, &nGirls, &nBoys);
getchar();

g_AdjNode[i - 1][j - 1].nBoys = nBoys;
g_AdjNode[i - 1][j - 1].nGirls = nGirls;
g_AdjNode[i - 1][j - 1].dRatio = (double)nGirls / nBoys;
g_AdjNode[j - 1][i - 1].nBoys = nBoys;
g_AdjNode[j - 1][i - 1].nGirls = nGirls;
g_AdjNode[j - 1][i - 1].dRatio = g_AdjNode[i - 1][j - 1].dRatio;

printf("Input finished?(y/n)");
scanf("%c", &q);
getchar();
} while ('y' != q);

//process here
nPathIndex = 0;
for (i = 0; i < nCities; i++)
{
FindPath(nPathIndex, 0);
nPathIndex = g_dRatio[0] <= g_dRatio[1] ? 0 : 1;
g_PathIndex[nPathIndex] = 0;
}

//output the result
nPathIndex = g_dRatio[0] >= g_dRatio[1] ? 0 : 1;
printf("The max ratio is %.3lf\n", g_dRatio[nPathIndex]);\
printf("The best path : \n");
for (i = 0; i < nCities; i++)
{
printf("%d\t", g_Path[nPathIndex][i]);
}
printf("\n");

return 0;
}

# re: 基本參數(shù)搜索  回復(fù)  更多評論   

2008-06-04 15:10 by Surfing
一點(diǎn)小問題,更正一下

if (g_PathIndex[nPathIndex] >= nCities)
{
g_dRatio[nPathIndex] = (double)nGirls / nBoys;
nGirls = nBoys = 0;
return 0;
}

# re: 基本參數(shù)搜索  回復(fù)  更多評論   

2008-06-04 17:13 by oyjpart
@Surfing
嘿嘿,謝謝分享

# re: 基本參數(shù)搜索  回復(fù)  更多評論   

2008-06-05 22:27 by w
多謝,受教了

# re: 基本參數(shù)搜索  回復(fù)  更多評論   

2008-06-05 23:07 by oyjpart
不謝

# re: 基本參數(shù)搜索  回復(fù)  更多評論   

2008-06-09 23:54 by richardxx
我做了百度那題,但比賽完才想起我貼的那個(gè)模版有點(diǎn)問題,最后果然只有4.5分,和沒做沒區(qū)別~~

# re: 基本參數(shù)搜索  回復(fù)  更多評論   

2008-06-10 12:03 by oyjpart
@richardxx
呵呵 進(jìn)復(fù)賽了就可以了不 看我們這種初賽就被水掉的菜菜。。

# re: 基本參數(shù)搜索  回復(fù)  更多評論   

2008-06-10 20:01 by 小Young
跟著大牛漲經(jīng)驗(yàn)值!

# re: 基本參數(shù)搜索  回復(fù)  更多評論   

2008-06-10 20:34 by oyjpart
汗。。。
您謙虛了。。。

# re: 基本參數(shù)搜索  回復(fù)  更多評論   

2008-06-11 19:12 by 小Young
請問這題你用隊(duì)列有什么用途啊?
這題不用隊(duì)列也可以啊.

# re: 基本參數(shù)搜索  回復(fù)  更多評論   

2008-06-11 22:19 by oyjpart
@ 小Young
就是廣搜用的隊(duì)列
不用隊(duì)列你的意思是深搜么?

# re: 基本參數(shù)搜索  回復(fù)  更多評論   

2008-07-26 06:09 by lengbufang
看看!!!
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            欧美调教视频| 国产精品免费福利| 亚洲国产精品久久久久秋霞蜜臀| 久久国产视频网站| 欧美一区二区| 亚洲高清不卡在线观看| 欧美高清在线视频观看不卡| 欧美a级在线| 亚洲深夜福利视频| 一区二区三区日韩精品视频| 欧美视频久久| 久久精品一区蜜桃臀影院 | 亚洲免费一级电影| 亚洲男人第一av网站| 国产一区二区三区黄视频| 久久免费视频在线观看| 欧美成人一区二区三区片免费| a91a精品视频在线观看| 午夜精品久久久久久久99热浪潮| 激情综合在线| 一本久道久久久| 国产主播精品在线| 亚洲三级电影全部在线观看高清| 欧美另类一区二区三区| 欧美一区二区三区男人的天堂| 久久都是精品| 亚洲天堂成人| 久久婷婷国产麻豆91天堂| 中国亚洲黄色| 久久久www成人免费无遮挡大片| 亚洲精品欧美激情| 亚欧成人在线| 一本色道久久88亚洲综合88| 欧美一区二区三区精品电影| 日韩午夜免费视频| 久久国产福利国产秒拍| 亚洲私人黄色宅男| 老色鬼精品视频在线观看播放| 亚洲一区二区三区精品视频| 久久综合伊人77777麻豆| 亚洲综合大片69999| 久久亚洲私人国产精品va媚药| 亚洲男人的天堂在线观看| 欧美成人高清视频| 欧美综合国产精品久久丁香| 欧美日韩国产小视频| 蜜臀va亚洲va欧美va天堂| 国产精品视频一二三| 亚洲精品免费电影| 亚洲国产片色| 久久久久9999亚洲精品| 欧美在线视频导航| 欧美性感一类影片在线播放| 亚洲韩国精品一区| 在线色欧美三级视频| 久久成人免费| 久久久精品性| 国产亚洲视频在线| 亚洲欧美中文日韩在线| 亚洲欧美日韩国产| 欧美视频成人| 制服丝袜激情欧洲亚洲| 中国成人在线视频| 欧美日韩精品免费观看视一区二区 | 欧美激情aⅴ一区二区三区| 久久乐国产精品| 国产一区二区三区黄| 午夜精品久久久久影视| 欧美在线3区| 国产欧美欧美| 欧美一区二区视频观看视频| 久久精品国产第一区二区三区最新章节| 欧美日韩日韩| 亚洲色图在线视频| 欧美在线欧美在线| 国产在线乱码一区二区三区| 久久精品国产精品亚洲| 玖玖国产精品视频| 亚洲国产毛片完整版| 欧美成人免费大片| 亚洲乱码视频| 性欧美长视频| 在线观看欧美成人| 欧美大片免费久久精品三p | 亚洲线精品一区二区三区八戒| 亚洲综合精品自拍| 国产亚洲一区二区三区| 久久久亚洲精品一区二区三区| 久久亚洲电影| 亚洲美女黄色| 国产美女精品| 蜜桃久久av一区| 日韩一区二区电影网| 久久aⅴ国产欧美74aaa| 在线成人www免费观看视频| 欧美精品久久久久久久久久| 一区二区三区视频在线播放| 久久久99免费视频| 亚洲精选视频免费看| 国产精品免费一区二区三区在线观看| 亚洲欧美另类中文字幕| 欧美大胆人体视频| 亚洲欧美国产毛片在线| …久久精品99久久香蕉国产 | 玖玖视频精品| 亚洲天堂偷拍| 欧美承认网站| 欧美在线网址| 亚洲最新视频在线| 狠狠色2019综合网| 欧美视频一区二区三区…| 久久久久久亚洲精品杨幂换脸 | 久久亚洲春色中文字幕久久久| 亚洲精品乱码久久久久久| 久久久成人精品| 宅男噜噜噜66国产日韩在线观看| 国产午夜精品久久久| 欧美日韩精品久久久| 久久在线免费观看视频| 午夜精品久久久久久久99水蜜桃| 91久久精品www人人做人人爽| 久久激情视频久久| 一区二区三区视频免费在线观看 | 欧美日韩在线免费观看| 久久这里有精品视频| 亚洲欧美影院| 亚洲一二三区精品| 亚洲美女视频网| 欧美激情一区二区三区不卡| 久久久久久久久伊人| 欧美在线视频二区| 亚洲欧美日韩一区二区三区在线| 日韩视频在线免费观看| 亚洲国产欧美日韩另类综合| 狠狠色丁香婷婷综合久久片| 国产嫩草一区二区三区在线观看 | 国产精品久久久久秋霞鲁丝| 欧美大片免费观看在线观看网站推荐| 久久精品国语| 久久久www免费人成黑人精品| 欧美一区国产二区| 香蕉视频成人在线观看| 亚洲欧美日韩国产精品| 亚洲伊人一本大道中文字幕| 一本久久a久久精品亚洲| 99精品国产一区二区青青牛奶| 亚洲片在线资源| 亚洲三级影片| 日韩一级欧洲| 亚洲色图自拍| 午夜视频一区二区| 香蕉免费一区二区三区在线观看| 亚洲免费在线观看视频| 午夜精品视频网站| 久久精品30| 美日韩免费视频| 欧美日韩精品一本二本三本| 欧美日韩亚洲免费| 国产精品久久国产三级国电话系列| 欧美体内谢she精2性欧美| 国产精品成人免费| 国产日产欧产精品推荐色 | 亚洲激情自拍| 99av国产精品欲麻豆| 在线视频欧美日韩精品| 亚洲性线免费观看视频成熟| 亚洲综合欧美日韩| 久久精品91久久香蕉加勒比| 久久先锋资源| 91久久精品www人人做人人爽| 亚洲美女在线视频| 午夜伦理片一区| 狂野欧美激情性xxxx| 欧美日韩国产色视频| 国产精品亚洲一区| 亚洲国产成人精品女人久久久 | 日韩午夜在线观看视频| 亚洲欧美成人在线| 老司机免费视频一区二区三区| 欧美精品一区二区三| 国产日韩欧美一区| 亚洲精品色婷婷福利天堂| 性欧美1819性猛交| 欧美激情第一页xxx| 一本色道久久综合狠狠躁的推荐| 午夜日韩福利| 欧美精品九九99久久| 国产女主播一区二区三区| 亚洲精品久久久久久下一站| 午夜欧美大片免费观看| 欧美电影免费观看高清| 亚洲在线1234| 欧美日韩国产精品自在自线| 国产视频在线观看一区二区| 日韩视频在线一区二区| 久久综合999| 亚洲综合好骚| 欧美女激情福利| 亚洲国产精品一区在线观看不卡| 欧美一区二区三区播放老司机 |