Truck History(prime)
| Time Limit: 2000MS | Memory Limit: 65536K | |
| Total Submissions: 31871 | Accepted: 12427 |
Description
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 to is the original type and td the type derived from it and d(to,td) 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
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
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.
#include <iostream>
#include <cstring>
#include <cstdio>
using namespace std;
#define N 2010
#define M 10 char str[N][M];//放字符串
int n;//结点数
int vis[N],dst[N],map[N][N]; //vis访问数组,dst放各点到MST的最小距离 int finddst(int i,int j)//找两字符串字符不同的列数
{
int num=0,k; for (k=0;k<7;k++)
{
if(str[i][k]!=str[j][k])
{
num++;
}
}
return num;
} void init()
{
int j,i; memset(vis,0,sizeof(vis));//访问数组初始
for (i=0;i<n;i++)//初始化图
{
for (j=0;j<n;j++)
{
if (i==j)
{
map[i][j]=0;
} map[i][j]=finddst(i,j);
}
}
} void prime()
{
int i,j,min,point,ans=0; vis[0]=1;//0点放入MST
for (i=0;i<n;i++)//dst初始化
{
dst[i]=map[i][0];
} for (i=1;i<n;i++)
{
min=N;
for (j=0;j<n;j++)//找距MST最近的点
{
if (vis[j]==0&&min>dst[j])
{
min=dst[j];
point=j;
}
} if (min==N)//不连通情况
{
break;
} vis[point]=1;//把该点放入MST
ans=ans+dst[point]; for (j=0;j<n;j++)//更新各点到MST的最小距离
{
if (vis[j]==0&&dst[j]>map[point][j])
{
dst[j]=map[point][j];
}
}
} printf("The highest possible quality is 1/%d.\n",ans);
} int main()
{
int i,j; while (scanf("%d",&n)&&n)
{
for (i=0;i<n;i++)
{
scanf("%s",&str[i]);
} init();
prime();
} return 0;
}
Truck History(prime)的更多相关文章
- POJ 1789 Truck History (最小生成树)
Truck History 题目链接: http://acm.hust.edu.cn/vjudge/contest/124434#problem/E Description Advanced Carg ...
- Truck History(最小生成树)
poj——Truck History Time Limit: 2000MS Memory Limit: 65536K Total Submissions: 27703 Accepted: 10 ...
- POJ 1789 -- Truck History(Prim)
POJ 1789 -- Truck History Prim求分母的最小.即求最小生成树 #include<iostream> #include<cstring> #incl ...
- poj 1789 Truck History(最小生成树)
模板题 题目:http://poj.org/problem?id=1789 题意:有n个型号,每个型号有7个字母代表其型号,每个型号之间的差异是他们字符串中对应字母不同的个数d[ta,tb]代表a,b ...
- 【POJ 1789】Truck History(最小生成树)
题意:距离定义为两个字符串的不同字符的位置个数.然后求出最小生成树. #include <algorithm> #include <cstdio> #include <c ...
- History(历史)命令用法
如果你经常使用 Linux 命令行,那么使用 history(历史)命令可以有效地提升你的效率.本文将通过实例的方式向你介绍 history 命令的用法. 使用 HISTTIMEFORMAT 显示时间 ...
- History(历史)命令用法15例
导读 如果你经常使用 Linux 命令行,那么使用 history(历史)命令可以有效地提升你的效率,本文将通过实例的方式向你介绍 history 命令的 15 个用法. 使用 HISTTIMEFOR ...
- [转] Linux History(历史)命令用法 15 例
[From]https://linuxtoy.org/archives/history-command-usage-examples.html 如果你经常使用 Linux 命令行,那么使用 histo ...
- History(历史)命令用法 15 例
如果你经常使用 Linux 命令行,那么使用 history(历史)命令可以有效地提升你的效率.本文将通过实例的方式向你介绍 history 命令的 15 个用法. 使用 HISTTIMEFORMAT ...
随机推荐
- 使用jar命令打jar/war包、创建可执行jar包、运行jar包、及批处理脚本编写
jar 命令 jar 是一个jar.exe可执行命令,即可以生成jar文件,也可以生成war文件 使用示例:jar -cvf ../xxx.jar * -c create,创建新的归档文档 ...
- 深入浅出React的一些细节——State
(来源于: https://facebook.github.io/react/docs/state-and-lifecycle.html 翻译by:@TimRChen) Using State Cor ...
- leetCode题解之Number of Lines To Write String
1.题目描述 2.分析 使用一个map将字母和数字对应起来,方便后续使用. 3.代码 vector<int> numberOfLines(vector<int>& wi ...
- Error 'LINK : fatal error LNK1123: failure during conversion to COFF: file invalid or cor
转自:http://blog.csdn.net/junjiehe/article/details/16888197 采用红字方法可行,后来采用cmake生成sln文件时,又出现了该问题,采用了玫红色字 ...
- PHP SFTP应用(二)
SFTP应用(二) SFTP Server SSH2 sftp操作 FTP进行文件传输需要通过端口进行.一般所需端口为: 控制链路—TCP端口21.控制器端.用于发送指令给服务器以及等待服务器响应. ...
- Word、rss、HTML解析等dll
RSS.NET.dll RSS.NET是一款操作RSS feeds的开源.NET类库.它为解析和编写RSS feeds提供了一个可重用的对象模型.它完全兼容RSS 0.90, 0.91, 0.92, ...
- zabbix对网卡流量超出添加阈值
给网卡设置流量阈值: 配置告警路径: Configuration--Templates--Template OS Linux--Discovery--Network interface discove ...
- September 10th 2017 Week 37th Sunday
Dream most deep place, only then the smile is not tired. 梦的最深处,只有微笑不累. Everyday I expect I can go to ...
- 【名称解释】#001 IIS名词解释
关于[名称解释]类型的文章,会慢慢更新. 2015.02.06 更 应用程序池: 应用程序池是将一个或多个应用程序链接到一个或多个工作进程集合的配置. 因为应用程序池中的应用程序与其他应用程序被工作进 ...
- Alpha 冲刺报告(10/10)
Alpha 冲刺报告(10/10) 队名:洛基小队 峻雄(组长) 已完成:阿尔法版的ppt 明日计划:总结阿尔法版的问题 剩余任务:角色属性脚本的完整版本 困难:缺乏编码经验,编码进度比较慢 ---- ...