ACM/ICPC 之 最短路径-dijkstra范例(ZOJ2750-POJ1135(ZOJ1298))

时间:2022-02-15 03:16:53

最短路经典算法-dijkstra范例(两道),第一道是裸的dijkstra,第二道需要枚举所有边已找到可能的情况。


ZOJ2750-Idiomatic Phrases Game

  题意:见Code

  题解:dijkstra算法需要理解的是松弛操作,这一点掌握好了,其他的代码书写则有点类似于Prim算法,易于掌握。

     本题需要记录每一个成语的前4个字符和后4个字符以记录成语的第一个字和最后一个字,博主省略了建图的过程,直接重载了Idiom结构体的“==”运算符,在dijkstra也直接使用了该判断,经过分析可以知道这种算法和利用邻接矩阵建图后再进行dijkstra的算法时间度基本一致O(n^2),因此权当简化代码也好。

 //成语接龙-dijkstra
//求从第一个成语道最后一个成语最短耗时(第一个列数据为T,表示需要耗时T后才能接龙下一个成语)
//Time:50Ms Memory:292K
#include<iostream>
#include<cstring>
#include<cstdio>
#include<vector>
#include<algorithm>
using namespace std; #define MAX 1001
#define INF 0x3f3f3f3f struct Idiom {
int time;
char pre[], rear[];
friend bool operator == (Idiom id1, Idiom id2) { return !strcmp(id1.rear, id2.pre); }
}idiom[MAX]; int n;
int d[MAX], mintime; //mintime:最短路耗时
bool v[MAX]; void dijkstra()
{
memset(v, false, sizeof(v));
memset(d, INF, sizeof(d));
v[] = true;
mintime = -; //默认失败
for (int i = ; i < n; i++)
{
if (idiom[] == idiom[i])
d[i] = idiom[].time;
}
for (int i = ; i < n; i++)
{
int mind = INF;
int k;
for (int j = ; j < n;j++)
{
if (!v[j] && mind > d[j])
{
mind = d[j];
k = j;
}
} if (mind == INF) return; //失败
if (k == n - ) { //成功
mintime = d[k];
return;
}
v[k] = true;
for (int j = ; j < n; j++)
if (!v[j] && idiom[k] == idiom[j]) d[j] = min(d[k] + idiom[k].time, d[j]);
}
} int main()
{
while (scanf("%d", &n), n)
{
char str[];
for (int i = ; i < n; i++)
{
scanf("%d%s", &idiom[i].time, str);
int len = strlen(str);
for (int j = ; j < ; j++)
{
idiom[i].pre[j] = str[j];
idiom[i].rear[j] = str[len - + j];
}
idiom[i].pre[] = idiom[i].rear[] = '\0';
} dijkstra();
printf("%d\n", mintime);
} return ;
}

POJ1135(ZOJ1298)-Domino Effect

  题意及题解:见Code注释部分

 //求从1开始倒下的多米诺骨牌最后倒下的时间及在何处倒下(在两个关键牌中间倒下则输出两个关键牌)
//dijkstra计算最短路,而后枚举每一条边上的时间(不一定在最短路的最大时间点和次大时间点内),以计算最后倒下的时间
//Time:32Ms Memory:1176K
#include<iostream>
#include<cstring>
#include<cstdio>
#include<algorithm>
using namespace std; #define MAX 505
#define INF 0x3f3f3f3f int n, m;
int map[MAX][MAX]; //如果MAX达10^4以上,考虑用邻接表
int d[MAX];
bool v[MAX];
int pos; //关键牌编号
double maxtime; //关键牌最后倒下的时间 void dijkstra()
{
memset(v, false, sizeof(v));
memset(d, , sizeof(d));
pos = ; //默认
maxtime = ;
v[] = true;
for (int i = ; i <= n; i++)
d[i] = map[i][];
for (int i = ; i <= n; i++)
{
int mind = INF;
int k = ;
for (int j = ; j <= n; j++)
{
if (!v[j] && mind > d[j])
{
mind = d[j];
k = j;
}
} maxtime = mind;
pos = k;
v[k] = true;
for (int j = ; j <= n; j++) //松弛
if (!v[j]) d[j] = min(d[k] + map[k][j], d[j]);
} }
int main()
{
int cas = ;
while (scanf("%d%d", &n, &m), n || m)
{
memset(map, INF, sizeof(map));
for (int i = ; i < m; i++)
{
int u, v, w;
scanf("%d%d%d", &u, &v, &w);
map[u][v] = map[v][u] = w;
}
dijkstra(); printf("System #%d\n", ++cas);
bool flag = false; //存在关键牌外的牌倒下时间更多的情况
int pos1, pos2;
for (int i = ; i <= n; i++)
for (int j = i + ; j <= n; j++)
{
if (map[i][j] != INF && (d[i] + d[j] + map[i][j]) / 2.0 > maxtime)
{
maxtime = (d[i] + d[j] + map[i][j]) / 2.0;
pos1 = i; pos2 = j;
flag = true;
}
} if (flag)
printf("The last domino falls after %.1f seconds, between key dominoes %d and %d.\n\n", maxtime, pos1, pos2);
else printf("The last domino falls after %.1f seconds, at key domino %d.\n\n", maxtime, pos);
}
return ;
}

ACM/ICPC 之 最短路径-dijkstra范例(ZOJ2750-POJ1135(ZOJ1298))的更多相关文章

  1. ACM&sol;ICPC 之 最短路径-Bellman Ford范例&lpar;POJ1556-POJ2240&rpar;

    两道Bellman Ford解最短路的范例,Bellman Ford只是一种最短路的方法,两道都可以用dijkstra, SPFA做. Bellman Ford解法是将每条边遍历一次,遍历一次所有边可 ...

  2. ACM&sol;ICPC 之 拓扑排序范例&lpar;POJ1094-POJ2585&rpar;

    两道拓扑排序问题的范例,用拓扑排序解决的实质是一个单向关系问题 POJ1094(ZOJ1060)-Sortng It All Out 题意简单,但需要考虑的地方很多,因此很容易将code写繁琐了,会给 ...

  3. ACM - ICPC World Finals 2013 C Surely You Congest

    原题下载:http://icpc.baylor.edu/download/worldfinals/problems/icpc2013.pdf 题目翻译: 试题来源 ACM/ICPC World Fin ...

  4. 2014嘉杰信息杯ACM&sol;ICPC湖南程序设计邀请赛暨第六届湘潭市程序设计竞赛

    比赛链接: http://202.197.224.59/OnlineJudge2/index.php/Contest/problems/contest_id/36 题目来源: 2014嘉杰信息杯ACM ...

  5. ACM&sol;ICPC 之 BFS&lpar;离线&rpar;&plus;康拓展开&lpar;TSH OJ-玩具&lpar;Toy&rpar;&rpar;

    祝大家新年快乐,相信在新的一年里一定有我们自己的梦! 这是一个简化的魔板问题,只需输出步骤即可. 玩具(Toy) 描述 ZC神最擅长逻辑推理,一日,他给大家讲述起自己儿时的数字玩具. 该玩具酷似魔方, ...

  6. ACM ICPC 2015 Moscow Subregional Russia&comma; Moscow&comma; Dolgoprudny&comma; October&comma; 18&comma; 2015 G&period; Garden Gathering

    Problem G. Garden Gathering Input file: standard input Output file: standard output Time limit: 3 se ...

  7. ACM ICPC 2015 Moscow Subregional Russia&comma; Moscow&comma; Dolgoprudny&comma; October&comma; 18&comma; 2015 D&period; Delay Time

    Problem D. Delay Time Input file: standard input Output file: standard output Time limit: 1 second M ...

  8. hduoj 4710 Balls Rearrangement 2013 ACM&sol;ICPC Asia Regional Online —— Warmup

    http://acm.hdu.edu.cn/showproblem.php?pid=4710 Balls Rearrangement Time Limit: 6000/3000 MS (Java/Ot ...

  9. 【转】lonekight&commat;xmu&&num;183&semi;ACM&sol;ICPC 回忆录

    转自:http://hi.baidu.com/ordeder/item/2a342a7fe7cb9e336dc37c89 2009年09月06日 星期日 21:55 初识ACM最早听说ACM/ICPC ...

随机推荐

  1. C&num;编写window服务,一步一步(1)

    Window服务是啥,这里就不废话了,如何用在哪里用也不废话了,这里我这篇文章只是详述了我在vs2012中创建window服务的经过,希望对你有所帮助. 另外:我在编写服务过程中参考了 Profess ...

  2. GPUImage 内置滤镜解析

    #pragmamark - 调整颜色 Handle Color GPUImageBrightnessFilter //亮度GPUImageExposureFilter //曝光GPUImageCont ...

  3. 《Apache服务用户身份验证管理》RHEL6&period;3

    1.安装apache软件包 Yum install httpd 2.启动apache服务 /etc/init.d/httpd restart 3.创建一个目录,内编辑一个index.html文件 4. ...

  4. Mysql 临时变量的 定义 和 赋值 Set 和 Into 赋值&semi; Swith Mysql版本 Case When的用法

    一:临时变量的定义和赋值 DECLARE spot SMALLINT; -- 分隔符的位置 DECLARE tempId VARCHAR(64); -- 循环 需要用到的临时的Cid DECLARE ...

  5. 聚类算法初探(六)OPTICS

    最近由于工作需要,对聚类算法做了一些相关的调研.现将搜集到的资料和自己对算法的一些理解整理如下,供大家参考. 另外在算法代码方面,我也做了一些实现(包括串行和并行),欢迎感兴趣的朋友探讨和交流. 第一 ...

  6. dedecms 织梦显示时间格式

    field:pubdate function=GetDateMK(@me)/] 2009-11-10 [field:pubdate function=GetDateTimeMK(@me)/] 2009 ...

  7. string&period;Format对C&num;字符串格式化

    String.Format 方法的几种定义: String.Format (String, Object) 将指定的 String 中的格式项替换为指定的 Object 实例的值的文本等效项.Stri ...

  8. 2&period;关于Apache Spark

    关于Apache Spark 1 Why Apache Spark 2 关于Apache Spark 3 如何安装Apache Spark 4 Apache Spark的工作原理 5 spark弹性分 ...

  9. &lpar;Linux&rpar;初探cmake &period;和make命令

    cmake编译OpenCV工程 首先我们看到文件夹中有一cpp文件,CMakeLists.txt文件和一张图片 首先进行cmake .命令 接着进行make命令 . 然后就得到了可执行文件,也就是说可 ...

  10. CSS的进一步深入(更新中&&num;183&semi;&&num;183&semi;&&num;183&semi;)

    在之前我们学了6种选择器和三种CSS样式的引入,学习选择器就是为了更好的选择文本,学习CSS的引入是为了使文本增加各种样式和属性, 下面我们简单来学习一下为文本加样式和一些属性和属性值: 1.文本的样 ...