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

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

POJ 1789 Truck History

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

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
欧美性猛交xxxx乱大交3| 欧美午夜视频在线观看| 国产亚洲一区二区精品| 精品女同一区二区三区在线播放| 国产精品久久久久久亚洲影视| 久久久久久久久综合| 中文字幕欧美精品日韩中文字幕| www.日韩不卡电影av| 色婷婷综合成人av| 国产乱人伦真实精品视频| 亚洲电影免费观看高清完整版在线| 日韩av网址在线观看| 欧美在线视频免费播放| 国产精品三级网站| 亚州av一区二区| 久久久999成人| 欧美在线免费看| 91精品在线影院| 国产91免费观看| 91最新国产视频| 亚洲老头老太hd| 国产精品va在线播放我和闺蜜| 久久男人资源视频| 中文亚洲视频在线| 欧美性猛交xxxxx水多| 欧美裸体xxxx极品少妇软件| 欧美激情欧美狂野欧美精品| 中文字幕无线精品亚洲乱码一区| 97精品国产97久久久久久免费| 亚洲精品一二区| 萌白酱国产一区二区| 国内精品国产三级国产在线专| 欧美中文字幕在线| 亚洲精品免费在线视频| 日韩视频在线免费观看| 午夜精品久久久久久久久久久久久| 亚洲加勒比久久88色综合| 久久亚洲国产成人| 91大神在线播放精品| 久久亚洲电影天堂| 国产精品久久久久9999| 国产91|九色| 成人免费xxxxx在线观看| 亚洲欧美综合v| 国模精品系列视频| 国产日韩av在线播放| 日韩av综合网站| 午夜精品在线视频| 精品国产一区二区三区久久久| 日韩在线中文字幕| 亚洲免费电影一区| 欧美日韩国产页| 国产精品99久久99久久久二8| 精品亚洲国产视频| 欧美疯狂xxxx大交乱88av| 91精品国产综合久久香蕉| 91精品久久久久久久久久另类| 91久久精品国产91性色| 在线观看日韩专区| 亚洲免费影视第一页| 欧美日韩国产中字| 日韩女优人人人人射在线视频| 国产精品自拍小视频| 日韩精品中文字幕视频在线| 欧美日韩一二三四五区| 色七七影院综合| 在线播放国产一区二区三区| 欧美壮男野外gaytube| 成人免费网视频| 97国产精品免费视频| 欧美重口另类videos人妖| 欧美大片免费观看在线观看网站推荐| 成人在线免费观看视视频| 午夜精品国产精品大乳美女| 国语自产精品视频在线看| 国产99久久精品一区二区| 日韩美女福利视频| 久热爱精品视频线路一| 色哟哟亚洲精品一区二区| 日本久久久久久久| 欧美乱妇40p| 人人爽久久涩噜噜噜网站| 欧美精品一区二区免费| 国产精品久久久久久久久免费看| 一色桃子一区二区| 精品国产乱码久久久久久天美| 成人免费激情视频| 日韩在线精品视频| 91久久精品久久国产性色也91| 不用播放器成人网| 亚洲美女自拍视频| 日本国产高清不卡| 欧美老女人bb| 亚洲无亚洲人成网站77777| 在线日韩av观看| 国产精品毛片a∨一区二区三区|国| 欧美大片在线看免费观看| 91久久精品日日躁夜夜躁国产| 日韩高清人体午夜| 国产亚洲欧美视频| 国产香蕉97碰碰久久人人| 伊人伊人伊人久久| 97精品视频在线| 国产一区二区三区欧美| 中文字幕亚洲欧美一区二区三区| 欧美激情videos| 成人在线一区二区| 久久青草精品视频免费观看| 精品一区二区三区四区在线| 亚洲开心激情网| 国产精品27p| 欧美激情亚洲激情| 亚洲精品久久久久久久久久久久久| 国产精品久久婷婷六月丁香| 欧美成人在线网站| 在线看国产精品| 国内精品中文字幕| 久久国产精品影视| 中文字幕亚洲一区| 日韩精品极品在线观看播放免费视频| 韩国三级日本三级少妇99| 在线成人免费网站| 岛国精品视频在线播放| 日韩免费av片在线观看| 91av免费观看91av精品在线| 欧美日韩日本国产| 欧美亚洲日本网站| 久国内精品在线| 最近2019好看的中文字幕免费| 久久久极品av| 日本电影亚洲天堂| 亚洲国产精品专区久久| 97碰碰碰免费色视频| 亚洲精品免费在线视频| 国产精品欧美日韩一区二区| 亚洲成人久久网| 亚洲精品福利视频| 亚洲欧美日韩精品久久奇米色影视| 91精品国产综合久久久久久久久| 亚洲最大成人在线| 国产国语刺激对白av不卡| 亚洲欧美激情视频| 亚洲一区二区三区在线免费观看| 8050国产精品久久久久久| 91国语精品自产拍在线观看性色| 欧美激情亚洲自拍| 精品国产乱码久久久久酒店| 亚洲成av人片在线观看香蕉| 尤物精品国产第一福利三区| 亚洲精品二三区| 在线看日韩欧美| 久久国产精品久久精品| 欧日韩不卡在线视频| 国产成人综合av| 俺去了亚洲欧美日韩| 亚洲free嫩bbb| 亚洲韩国欧洲国产日产av| 亚洲成av人乱码色午夜| 欧美—级a级欧美特级ar全黄| 欧美性猛交xxxx黑人| 精品亚洲国产成av人片传媒| 国产精品入口福利| 久久久国产一区| 亚洲欧美三级伦理|