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

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) 評(píng)論(14)  編輯 收藏 引用 所屬分類: ACM/ICPC或其他比賽

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

后來從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ù)  更多評(píng)論   

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

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

2008-06-04 14:56 by oyjpart
你可以參考《算法藝術(shù)與信息學(xué)競(jìng)賽》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ù)  更多評(píng)論   

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ù)  更多評(píng)論   

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ù)  更多評(píng)論   

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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>
            欧美夫妇交换俱乐部在线观看| 欧美视频中文一区二区三区在线观看 | 久久久久久久久综合| 欧美日韩精品一区二区三区四区| 欧美国产日韩精品| 亚洲精品日产精品乱码不卡| 久久久噜久噜久久综合| 久久只精品国产| 精品999网站| 久久免费高清| 亚洲人成毛片在线播放| 久久综合网hezyo| 亚洲国产精品高清久久久| 日韩午夜在线视频| 欧美特黄一区| 欧美日产国产成人免费图片| 久久久久久久一区二区三区| 欧美一级欧美一级在线播放| 老司机精品导航| 亚洲精品国产精品国自产观看| 国内精品久久久久影院薰衣草| 久久国产精品电影| 最新国产成人av网站网址麻豆 | 久久欧美肥婆一二区| 亚洲国产欧洲综合997久久| 欧美日韩成人一区二区三区| 久热精品视频在线观看| 久久视频在线看| 久久久一本精品99久久精品66| 欧美主播一区二区三区美女 久久精品人 | 亚洲福利免费| 午夜视频在线观看一区二区三区| 国产午夜精品一区二区三区欧美| 久久五月天婷婷| 久久夜色精品国产| 久久一区二区视频| 欧美aaa级| 亚洲小说春色综合另类电影| 久久久久久久综合色一本| 欧美一区二视频| 日韩视频欧美视频| 狠狠色丁香久久综合频道 | 国产一区二区三区精品欧美日韩一区二区三区 | 国产精品天天摸av网| 久久裸体视频| 另类春色校园亚洲| 免费亚洲一区二区| 欧美激情视频在线播放| 欧美一区二区黄| 久久久久国产精品人| 久久综合电影| 欧美高清视频一二三区| 久久精品最新地址| 亚洲伊人网站| 日韩视频在线你懂得| 久久综合伊人77777| 美女主播一区| 久久九九国产| 欧美岛国在线观看| 99亚洲伊人久久精品影院红桃| 久久在线免费| 亚洲高清资源| 一区二区三区日韩精品| 亚洲精品国产拍免费91在线| 一本久久知道综合久久| 午夜精品视频网站| 99re8这里有精品热视频免费| 亚洲天堂偷拍| 美女日韩在线中文字幕| 久久夜色精品亚洲噜噜国产mv| 欧美成人免费大片| 毛片一区二区三区| 欧美午夜一区二区三区免费大片| 欧美日韩成人一区| 国产日韩亚洲| 99视频一区二区三区| 亚洲精品一区二| 欧美一级成年大片在线观看| 亚洲一区在线观看免费观看电影高清| 91久久夜色精品国产网站| 亚洲激情视频在线| 欧美一区二区三区播放老司机| 美女诱惑一区| 亚洲制服欧美中文字幕中文字幕| 亚洲一区二区成人| 久久综合色天天久久综合图片| 国产精品国产三级国产普通话三级| 国产精品av一区二区| 亚洲福利视频网站| 亚洲日本中文字幕免费在线不卡| 亚洲欧美中文在线视频| 欧美高清视频在线观看| 亚洲一区二区av电影| 欧美成人免费在线观看| 国产日本欧美视频| 激情六月婷婷综合| 亚洲综合三区| 亚洲激情av| 久久久久久九九九九| 国产精品久久久久久av下载红粉| 亚洲激情一区二区| 老司机午夜免费精品视频 | 亚洲素人一区二区| 亚洲欧美日韩一区在线观看| 欧美在线视频免费观看| 蜜臀va亚洲va欧美va天堂| 亚洲影视在线播放| 欧美日韩不卡视频| 日韩视频在线观看一区二区| 久久中文精品| 欧美中文字幕精品| 国产精品一区二区久久精品| 在线观看视频一区二区欧美日韩| 亚洲精品久久久久久久久久久| 久久久久国产一区二区| 亚洲欧美日韩第一区| 久久亚洲欧美| 极品少妇一区二区| 久久精品一区二区| 午夜精品国产更新| 国产精品视频免费一区| 亚洲午夜精品久久久久久app| 久久爱www久久做| 亚洲综合好骚| 国产精品夜夜夜| 欧美一区二区女人| 欧美亚洲三区| 国产在线精品二区| 久久蜜桃精品| 久久久久久精| 亚洲国产三级网| 亚洲第一色在线| 欧美成人第一页| 亚洲精品乱码久久久久久蜜桃91| 亚洲国产精品成人va在线观看| 欧美成人一品| 在线视频欧美一区| 免费亚洲视频| 欧美大片免费观看| 99国产精品自拍| 99日韩精品| 国产精品久久久一区二区| 日韩午夜av| 一区二区欧美在线| 国产九九视频一区二区三区| 久久av一区二区三区漫画| 欧美影院视频| 亚洲欧洲在线一区| 日韩午夜免费视频| 国产欧美一区二区色老头 | 一区二区三区视频观看| 国产精品免费一区二区三区在线观看| 欧美影院成年免费版| 久久国产精品久久精品国产| …久久精品99久久香蕉国产| 欧美亚洲综合在线| 久久国产精品免费一区| 亚洲国产精品美女| 99xxxx成人网| 国产一区999| 亚洲国产精品一区二区www| 欧美色123| 久久久久久69| 欧美日本久久| 亚洲精品麻豆| 亚洲伊人久久综合| 亚洲高清在线观看| 一区二区成人精品| 狠狠色综合网| 一本色道精品久久一区二区三区 | 亚洲伊人色欲综合网| 在线观看精品视频| 正在播放日韩| 国产精品大片wwwwww| 久久精品国产一区二区三| 欧美一级成年大片在线观看| 亚洲国产另类精品专区| 在线性视频日韩欧美| 精品二区视频| 一区二区久久久久| 在线日韩av片| 亚洲一区二区三区视频| 亚洲片区在线| 久久国产精品99久久久久久老狼 | 欧美一区二区大片| 一本色道久久综合亚洲精品婷婷| 欧美一区二区三区视频在线| 在线一区二区三区四区五区| 久久久www成人免费精品| 亚洲一区二区三区中文字幕在线| 久久久久久久网| 欧美在线视频在线播放完整版免费观看 | 欧美一区久久| 欧美日韩精品不卡| 欧美成人精品| 欧美激情一区三区| 鲁大师成人一区二区三区| 国产精品国产三级国产专区53 | 日韩亚洲欧美在线观看| 在线看国产一区|