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

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

POJ 1789 Truck History

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

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在线观看| 国产欧美日韩丝袜精品一区| 国产综合香蕉五月婷在线| 久久福利网址导航| 91久久久久久久久久久久久| 日本精品久久久久久久| 日韩欧美在线免费观看| 亚洲视频一区二区三区| 亚洲美女福利视频网站| 中文字幕精品视频| 国产成人精品一区二区在线| 久久久久久久成人| 青青草原一区二区| 视频在线一区二区| 国模吧一区二区| 色偷偷av一区二区三区乱| 亚洲精品国产精品自产a区红杏吧| 亚洲男人天堂手机在线| 亚洲男人av电影| 亚洲在线一区二区| 国产成人亚洲综合| 久久久久在线观看| 亚洲一区免费网站| 91精品国产九九九久久久亚洲| 亚洲天堂网在线观看| 亚洲国产精品va在线看黑人| 日韩电影中文字幕一区| 欧美亚洲午夜视频在线观看| 欧美日韩国产一区中文午夜| 久久久久久久久国产| 国内自拍欧美激情| 51精品国产黑色丝袜高跟鞋| 色午夜这里只有精品| 久久视频中文字幕| 九九精品在线视频| 亚洲最新av网址| 国产视频在线观看一区二区| 国产国语videosex另类| 亚洲精品福利资源站| 精品福利免费观看| 亚洲成人a级网| 国产日韩综合一区二区性色av| 日韩在线观看免费高清| 亚洲自拍小视频免费观看| 欧美老女人性生活| 日韩av网站电影| 欧美一区二区三区免费视| 在线日韩日本国产亚洲| 欧美成人精品激情在线观看| 欧美一区视频在线| 国产日韩在线精品av| 狠狠色狠色综合曰曰| 久久成人亚洲精品| 色偷偷偷亚洲综合网另类| 亚洲第一页自拍| 亚洲天堂av在线播放| 久久精品国产成人精品| 国产精品中文在线| 国产精品18久久久久久麻辣| 日韩欧美亚洲成人| 亚洲一区二区在线| 91精品国产91久久久久| 久久精品国产一区二区三区| 亚洲最大成人免费视频| 欧美国产精品va在线观看| 国产日韩欧美视频| 成人网在线免费观看| 欧美精品制服第一页| 97久久伊人激情网| 亚洲人成啪啪网站| 国产精品欧美亚洲777777| 久久亚洲春色中文字幕| 欧美做爰性生交视频| 毛片精品免费在线观看| 性欧美xxxx| 亚洲娇小xxxx欧美娇小| 国内精品400部情侣激情| 国产九九精品视频| 久久免费视频这里只有精品| 97超视频免费观看| 亚洲第一网站免费视频| 国产日韩精品在线观看| 日本久久久久亚洲中字幕| 国产精品成人播放| 亚洲自拍偷拍色图| 国产精品久久77777| 国自产精品手机在线观看视频| 日韩成人av在线| 国产精品91久久| 成人福利网站在线观看11| 日韩精品欧美激情| 亚洲 日韩 国产第一| 亚洲电影免费观看高清完整版在线| 国模视频一区二区三区| 日韩av资源在线播放| 欧美一级片在线播放| 日韩精品极品视频| 日韩国产在线播放| 青青草一区二区| 欧美在线视频播放| 国产精品一区二区av影院萌芽| 色视频www在线播放国产成人| 亚洲欧洲av一区二区| 国产精品久久不能| 久久69精品久久久久久久电影好| 亚洲精品一区二区久| 欧美激情欧美激情在线五月| 亚洲аv电影天堂网| 欧美性20hd另类| 国产日韩综合一区二区性色av| 日韩美女激情视频| 欧美三级欧美成人高清www| 亚洲午夜精品视频| 久久久国产精品一区| 欧美性感美女h网站在线观看免费| 亚洲天堂开心观看| 久久久久久久久电影| 欧美一区在线直播| 日韩中文字幕视频在线观看| 精品国偷自产在线视频| 不卡在线观看电视剧完整版| 亚洲精品国产精品国自产在线| 国产91色在线|免| 欧美午夜激情在线| 91av免费观看91av精品在线| 一区二区成人精品| 国模极品一区二区三区| 国产精品久久久久影院日本| 欧美成aaa人片在线观看蜜臀| 久久九九全国免费精品观看| 久久久噜久噜久久综合| 不卡av电影在线观看| 欧美日韩国内自拍| 亚洲国产古装精品网站| 日韩精品亚洲精品| 亚洲高清av在线| 国产婷婷97碰碰久久人人蜜臀| 中文字幕亚洲欧美在线| 国内精品模特av私拍在线观看| 色婷婷av一区二区三区在线观看| 热门国产精品亚洲第一区在线| 黄色成人av在线| 懂色aⅴ精品一区二区三区蜜月| 国产精品免费在线免费| 国产精品美女久久久久久免费| 国内精品美女av在线播放| 日韩精品极品视频| 日韩久久免费电影| 欧美中文字幕精品| 久久视频这里只有精品| 91视频九色网站| 91免费看片在线| 日本久久久久亚洲中字幕| 91精品视频一区| 欧美日本啪啪无遮挡网站| 欧美亚洲国产日本| 国产一区深夜福利| 国产精品va在线播放我和闺蜜| 亚洲精品国精品久久99热一| 国语自产偷拍精品视频偷| 日韩成人激情在线| 精品视频在线播放色网色视频| 日韩天堂在线视频| 国产精品网站入口|