亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 學院 > 開發設計 > 正文

POJ 1789 Truck History

2019-11-14 10:04:10
字體:
來源:轉載
供稿:網友

Advanced Cargo Movement, Ltd. uses trucks of different types. Some trucks are used for vegetable delivery, other for furniture, or for bricks. The company has its own code describing each type of a truck. The code is simply a string of exactly seven lowercase letters (each letter on each position has a very special meaning but that is unimportant for this task). At the beginning of company’s history, just a single truck type was used but later other types were derived from it, then from the new types another types were derived, and so on.

Today, ACM is rich enough to pay historians to study its history. One thing historians tried to find out is so called derivation plan – i.e. how the truck types were derived. They defined the distance of truck types as the number of positions with different letters in truck type codes. They also assumed that each truck type was derived from exactly one other truck type (except for the first truck type which was not derived from any other type). The quality of a derivation plan was then defined as 1/Σ(to,td)d(to,td)

where the sum goes over all pairs of types in the derivation plan such that t o is the original type and t d the type derived from it and d(t o,t d) is the distance of the types. Since historians failed, you are to write a PRogram to help them. Given the codes of truck types, your program should find the highest possible quality of a derivation plan. Input The input consists of several test cases. Each test case begins with a line containing the number of truck types, N, 2 <= N <= 2 000. Each of the following N lines of input contains one truck type code (a string of seven lowercase letters). You may assume that the codes uniquely describe the trucks, i.e., no two of these N lines are the same. The input is terminated with zero at the place of number of truck types. Output For each test case, your program should output the text “The highest possible quality is 1/Q.”, where 1/Q is the quality of the best derivation plan. Sample Input 4 aaaaaaa baaaaaa abaaaaa aabaaaa 0 Sample Output The highest possible quality is 1/3. 題意:aaaaaaa是初始字符串。給一個數N,輸入N行字符串,兩行字符串相同位置的字符相異的數量為兩個字符串的距離。使用到所有的字符串,求距離之和的最小值。 一個字符串可以看成一個節點,兩個節點的邊就是字符串距離,求這個圖的最小生成樹的邊的和。 Kruskal求解

#include<iostream>#include<vector>#include<algorithm>#include<cstdlib>#include<cmath>#include<stack>#include<queue>#include<cstdio>#include<string>#include<cstring>#include<string.h>#include<map>#include<set>using namespace std;#define N 2000+5#define NN 10000#define INF 0x3f3f3f3f/*****************************************************/char str[N][10];int par[N];int ranks[N];struct node{ int u, v, w;};node s[4000000];bool cmp(node a, node b){ return a.w < b.w;}bool same(int a, int b);int find(int x);void unite(int a, int b);int main(){ int n; while (cin >> n){ if (n == 0)break; for (int i = 0; i < n; i++){ scanf("%s", str[i]); } int E = 0; int res = 0; for (int i = 0; i < n; i++){ for (int j = 1 + i; j < n; j++){ int cnt = 0; for (int k = 0; k < 7; k++){ if (str[i][k] != str[j][k]){ cnt++; } } s[E].u = i, s[E].v = j, s[E].w = cnt; E++; //邊的數量 } } sort(s, s + E, cmp); for (int i = 0; i < n; i++){ par[i] = i; ranks[i] = 1; } for (int i = 0; i < E; i++){ if (!same(s[i].u, s[i].v)){ unite(s[i].u, s[i].v); res += s[i].w; } } printf("The highest possible quality is 1/%d./n", res); }}int find(int x){ if (x == par[x])return x; return par[x] = find(par[x]);}bool same(int a, int b){ a = find(a); b = find(b); if (a == b)return true; return false;}void unite(int a, int b){ a = find(a); b = find(b); if (a == b)return; if (ranks[a] < ranks[b]){ par[a] = b; } else{ if (ranks[a] == ranks[b]) ranks[a]++; par[b] = a; }}

Prim求解

#include<iostream>#include<vector>#include<algorithm>#include<cstdlib>#include<cmath>#include<stack>#include<queue>#include<cstdio>#include<string>#include<cstring>#include<string.h>#include<map>#include<set>using namespace std;#define N 2000+5#define NN 10000#define INF 0x3f3f3f3f/*****************************************************/char str[N][10];int cost[N][N];int d[N];bool used[N];int main(){ int n; while (cin >> n){ if (n == 0)break; for (int i = 0; i < n; i++){ scanf("%s", str[i]); } memset(d, 0x3f, sizeof(d)); memset(used, 0, sizeof(used)); for (int i = 0; i < n; i++){ for (int j = 0; j < n; j++){ int cnt = 0; for (int k = 0; k < 7; k++){ if (str[i][k] != str[j][k]){ cnt++; } } cost[i][j] = cost[j][i] = cnt; } } d[0] = 0; int res = 0; while (1){ int v = -1; for (int i = 0; i < n; i++){ if (!used[i] && (v == -1 || d[i] < d[v])) v = i; } if (v == -1)break; used[v] = true; res += d[v]; for (int i = 0; i < n; i++){ d[i] = min(d[i], cost[v][i]); } } printf("The highest possible quality is 1/%d./n", res); }}
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
亚洲一级免费视频| 欧美在线观看网站| 91在线精品播放| 自拍偷拍免费精品| 奇米一区二区三区四区久久| 欧美专区日韩视频| 亚洲激情成人网| 亚洲电影中文字幕| 亚洲人成欧美中文字幕| 精品夜色国产国偷在线| 久久久免费在线观看| 国产精品入口免费视频一| 亚洲欧美综合v| 亚洲成人精品在线| 亚洲欧美中文另类| 色无极亚洲影院| 久久久噜噜噜久噜久久| 夜夜嗨av一区二区三区四区| 日本高清视频一区| 成人疯狂猛交xxx| 国产精品偷伦一区二区| 亚洲国产中文字幕久久网| 国产成人精品视频| xx视频.9999.com| 国产日韩综合一区二区性色av| 亚洲精品中文字幕女同| 精品视频在线导航| 欧美日韩成人在线视频| 欧美黑人xxx| 丁香五六月婷婷久久激情| 久久精彩免费视频| 久久理论片午夜琪琪电影网| 国产成人高清激情视频在线观看| 色综合久久天天综线观看| 国产精品爱啪在线线免费观看| 久久天天躁狠狠躁夜夜av| 色偷偷综合社区| 亚洲图片制服诱惑| 国产精品久久97| 欧美一区二区三区免费视| 欧美性色19p| 色99之美女主播在线视频| 欧美综合一区第一页| 欧美裸体xxxx极品少妇| 久久天天躁日日躁| 日产精品99久久久久久| 国内精久久久久久久久久人| 九色91av视频| 91精品视频在线| 亚洲欧美中文在线视频| 国产日韩视频在线观看| 美女福利精品视频| 亚洲精品美女免费| 中文字幕av一区二区三区谷原希美| 久久av中文字幕| 亚洲一区二区三区sesese| 尤物yw午夜国产精品视频| 欧美午夜激情小视频| 亚洲精品色婷婷福利天堂| 亚洲在线免费看| 日韩成人中文字幕| 亚洲第一级黄色片| 国产精品一区二区久久精品| 亚洲精品av在线播放| 欧美精品久久久久久久久| 麻豆乱码国产一区二区三区| 国产精品久久一区| 久久乐国产精品| 青青在线视频一区二区三区| 欧美最顶级丰满的aⅴ艳星| 福利二区91精品bt7086| 91av在线免费观看视频| 亚洲国产97在线精品一区| 亚洲aⅴ日韩av电影在线观看| 日韩欧美在线看| 欧美激情综合色综合啪啪五月| 国产日产亚洲精品| 亚洲欧美国产精品| 欧美国产日韩一区二区三区| 欧美在线视频免费播放| 国产亚洲精品久久久久久777| 欧美激情视频一区| 久久久免费电影| 成人女保姆的销魂服务| 97国产在线观看| 欧美性猛交xxxxx免费看| 色青青草原桃花久久综合| 亚洲热线99精品视频| 亚洲精品456在线播放狼人| 国产成人综合一区二区三区| 欧美极品第一页| 欧美另类高清videos| 国产视频自拍一区| 黑人极品videos精品欧美裸| 欧美成人黄色小视频| 成人免费观看网址| 亚洲国产成人久久| 久久亚洲国产成人| 98精品国产自产在线观看| 午夜欧美大片免费观看| 96精品视频在线| 久青草国产97香蕉在线视频| 精品久久久国产精品999| 日韩欧美高清视频| 51精品国产黑色丝袜高跟鞋| 久久久久久久97| 日本久久久久久久| 国产精品久久久久久影视| 日韩精品欧美国产精品忘忧草| 日韩一区二区福利| 国产日韩欧美日韩| 中文字幕一区日韩电影| 91sao在线观看国产| 日韩精品免费在线视频| 色噜噜狠狠狠综合曰曰曰88av| 国产一区二区三区丝袜| 欧美日韩黄色大片| 日韩av在线网| 亚洲国产天堂久久综合| 久久频这里精品99香蕉| 国产精品久久久久久久午夜| 国产精品成人免费电影| 91精品免费视频| 欧美性感美女h网站在线观看免费| 国产亚洲精品91在线| 国产精品专区一| 亚洲一区二区三区在线视频| 日韩人体视频一二区| 久久久久久久999精品视频| 尤物九九久久国产精品的特点| 69精品小视频| 日韩视频第一页| 日韩中文字幕在线精品| 国产97色在线| 国产极品精品在线观看| 精品高清美女精品国产区| 国产亚洲精品激情久久| 高跟丝袜一区二区三区| 亚洲白虎美女被爆操| 亚洲成人教育av| 亚洲欧美精品伊人久久| 亚洲综合日韩中文字幕v在线| 国内伊人久久久久久网站视频| 日本高清不卡在线| 国产精品久久久久7777婷婷| 最好看的2019的中文字幕视频| 在线观看精品自拍私拍| 亚洲一区二区在线| 亚洲国产精品久久| 亚洲精品成人免费| 国产精品麻豆va在线播放| 日韩在线国产精品| 日韩在线观看免费| 久久久精品一区二区三区| 福利一区视频在线观看| 欧美黑人性生活视频| 性色av一区二区三区红粉影视| 午夜剧场成人观在线视频免费观看| 久久精品国产精品| 国产精品人成电影在线观看| 久久精品中文字幕| 成人免费在线视频网站| 亚洲综合视频1区| 日韩精品在线视频美女|