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

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頁(yè)
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>
            亚洲国产另类久久久精品极度| 国产精品一区二区久久| 亚洲免费视频观看| 亚洲国产婷婷| 久久久久看片| 亚洲欧美电影在线观看| 免费毛片一区二区三区久久久| 亚洲视频1区| 欧美专区一区二区三区| 一二三四社区欧美黄| 亚洲国产老妈| 影音先锋中文字幕一区二区| 国产精品一区二区黑丝| 国产精品h在线观看| 欧美多人爱爱视频网站| 久久亚洲国产精品一区二区| 亚洲精品乱码久久久久久蜜桃91| 久久综合伊人77777蜜臀| 欧美一区二区三区免费观看视频| 中文一区二区在线观看| 一区二区不卡在线视频 午夜欧美不卡在 | 欧美—级在线免费片| 久久深夜福利| 久久天天躁狠狠躁夜夜爽蜜月| 香蕉免费一区二区三区在线观看| 亚洲视频二区| 亚洲一区在线视频| 亚洲午夜av在线| 亚洲午夜性刺激影院| 一区二区三区欧美在线| 99精品国产在热久久婷婷| 亚洲精品免费网站| 亚洲精选在线| 一区二区国产日产| 日韩香蕉视频| 亚洲先锋成人| 午夜精品福利视频| 欧美亚洲午夜视频在线观看| 欧美在线一二三| 久久久久久婷| 久久综合激情| 欧美黑人在线播放| 欧美日韩国产小视频在线观看| 欧美三日本三级三级在线播放| 欧美亚一区二区| 国产美女精品视频| 在线观看av不卡| 亚洲激情社区| 亚洲午夜av在线| 羞羞答答国产精品www一本| 久久国产精品久久国产精品| 久久久综合网站| 欧美激情一区二区三区不卡| 亚洲理伦在线| 香蕉国产精品偷在线观看不卡| 久久精品国产999大香线蕉| 另类国产ts人妖高潮视频| 欧美日本不卡视频| 国产精品三级久久久久久电影| 国产一区视频在线观看免费| 在线看一区二区| 一区二区三区久久精品| 久久爱另类一区二区小说| 美日韩精品免费| 亚洲精品一区二区三区不| 亚洲女人天堂av| 久久在线播放| 国产精品免费网站在线观看| 激情综合自拍| 99精品视频免费观看| 校园春色国产精品| 欧美激情一区二区三区在线| 亚洲婷婷国产精品电影人久久| 久久狠狠婷婷| 欧美午夜国产| 亚洲高清免费| 亚洲欧美国产精品桃花| 欧美成人在线免费视频| 亚洲午夜激情网页| 蜜臀av性久久久久蜜臀aⅴ| 国产精品毛片va一区二区三区| 在线欧美电影| 性色av香蕉一区二区| 亚洲二区免费| 久久精品30| 国产精品美女久久久久久久| 亚洲肉体裸体xxxx137| 欧美影院一区| 日韩亚洲欧美中文三级| 久久九九国产| 国产精品一区二区久久| 一本久久a久久精品亚洲| 久久资源av| 亚洲欧美一区二区三区极速播放| 欧美激情一区二区三区在线视频 | 欧美日韩一区在线| 有码中文亚洲精品| 欧美在线免费一级片| 日韩天堂在线视频| 免费亚洲电影| 黑丝一区二区| 欧美一区二区三区视频免费播放 | 亚洲人体一区| 久久免费精品视频| 国产亚洲综合精品| 亚洲欧美日韩视频二区| 亚洲欧洲精品一区二区三区不卡 | 久久久999| 国产毛片精品视频| 午夜精品久久久久久久久久久| 亚洲精品国精品久久99热一| 美腿丝袜亚洲色图| 在线观看精品| 久久综合中文| 久久久久久久久伊人| 国产日韩精品电影| 1024国产精品| 久久躁狠狠躁夜夜爽| 欧美伊人久久| 国产日韩成人精品| 久久av红桃一区二区小说| 亚洲一区二区视频| 国产精品黄色在线观看| 亚洲一区自拍| 一区二区三区视频观看| 欧美日韩一区二区免费在线观看| 日韩西西人体444www| 亚洲欧洲日韩综合二区| 欧美精品大片| 在线综合欧美| 99视频有精品| 国产精品美女视频网站| 性欧美暴力猛交另类hd| 午夜电影亚洲| 一区二区视频欧美| 免费永久网站黄欧美| 久久综合九色综合欧美狠狠| 最新日韩av| 亚洲精品视频免费在线观看| 国产精品白丝黑袜喷水久久久 | 亚洲福利电影| 欧美精品播放| 国产精品99久久99久久久二8| 一区二区欧美激情| 国产日本欧美一区二区三区在线| 久久精品论坛| 老司机成人网| 夜夜嗨av色综合久久久综合网| 夜夜嗨av色综合久久久综合网| 国产精品久久久久久久久久尿| 久久大逼视频| 久久伊人亚洲| 一区二区免费在线观看| 亚洲男人第一av网站| 一区二区视频在线观看| 亚洲国产高清高潮精品美女| 欧美四级电影网站| 久久精品久久综合| 欧美电影免费观看| 亚洲欧美成人一区二区三区| 午夜精品区一区二区三| 亚洲高清影视| 中文在线资源观看网站视频免费不卡 | 亚洲欧美日本日韩| 欧美在线观看一区二区| 亚洲国产精品ⅴa在线观看 | 亚洲精品视频在线播放| 国产精品jizz在线观看美国 | 欧美激情一区在线观看| 在线视频日韩精品| 性感少妇一区| 亚洲免费观看高清完整版在线观看熊 | 欧美久久一级| 久久av一区| 欧美精品aa| 久久精品在这里| 欧美精品亚洲精品| 久久精品在这里| 欧美日韩精品免费观看| 久久久久亚洲综合| 欧美日韩国产综合新一区| 久久精品夜色噜噜亚洲a∨| 欧美精品网站| 麻豆精品在线视频| 国产精品美女久久久| 亚洲福利精品| 红桃视频成人| 亚洲一区激情| 日韩视频第一页| 久久精品亚洲一区二区| 午夜精品视频| 欧美日韩国产精品专区| 男女激情久久| 国产一区二区三区观看| 一区二区动漫| 一本大道av伊人久久综合| 久久免费视频在线| 久久久久久久91| 国产精品揄拍500视频| 日韩亚洲欧美一区二区三区|