热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

[codevs2442]kshort经典题

constmaxn60;maxs500000;typeedgerecordu,v,w,pre:longint;end;pointrecordpath:string;f,now,le

const maxn=60;
maxs
=500000;
type edge=record
u,v,w,pre:longint;
end;
point
=record
path:string;
f,now,len:longint;
end;
var e:array[0..maxn*maxn*2]of edge;
last,que,d:
array[0..maxn]of longint;
v:
array[0..maxn]of boolean;
h:
array[0..maxs]of point;
tot:longint;
n,m,k,a,b,anslen:longint;
ans:string;
procedure addedge(u,v,w:longint);
begin
inc(tot);e[tot].u:
=u;e[tot].v:=v;e[tot].w:=w;
e[tot].pre:
=last[u];last[u]:=tot;
end;
procedure spfa(s:longint);
var l,r,tmp,u:longint;
begin
fillchar(que,sizeof(que),
0);
fillchar(v,sizeof(v),false);
fillchar(d,sizeof(d),
1);
l:
=0;r:=1;que[l]:=s;
v[s]:
=true;d[s]:=0;
while l<>r do
begin
u:
=que[l];
tmp:
=last[u];
while tmp<>0 do
begin
if (d[e[tmp].v]>d[u]+e[tmp].w)then
begin
d[e[tmp].v]:
=d[u]+e[tmp].w;
if not v[e[tmp].v] then
begin
que[r]:
=e[tmp].v;
inc(r);
if r=maxn then r:=0;
v[e[tmp].v]:
=true;
end;
end;
tmp:
=e[tmp].pre;
end;
v[u]:
=false;
inc(l);
if l=maxn then l:=0;
end;
end;
function compare(p,q:string):boolean;
var i,len1,len2,len:longint;
begin
len1:
=length(p);
len2:
=length(q);
if len1>len2 then len:=len2
else len:=len1;
for i:=1 to len do
begin
if p[i]>q[i] then exit(false);
if p[i]then exit(true);
end;
if len1>len2 then exit(true)
else exit(false);
end;
function cmp(p,q:point):boolean;
begin
if (p.for((p.f=q.f)and(compare(p.path,q.path))) then exit(true);
exit(false);
end;
procedure down(p,n:longint);
var j:longint;x:point;
begin
x:
=h[p];
j:
=p<<1;
while j<=n do
begin
if (jand(cmp(h[j+1],h[j]))then inc(j);
if cmp(x,h[j]) then j:=n+1
else begin
h[p]:
=h[j];
p:
=j;
j:
=j shl 1;
end;
end;
h[p]:
=x;
end;
procedure up(p:longint);
var j:longint;x:point;
begin
x:
=h[p];
j:
=p>>1;
while j>0 do
begin
if cmp(h[j],x) then j:=0
else begin
h[p]:
=h[j];
p:
=j;
j:
=j shr 1;
end;
end;
h[p]:
=x;
end;
procedure init;
var i,j,sav,now,tmp,u,v:longint;
x:point;
find:boolean;
xx:char;
begin
read(n,m,k,a,b);
{a*MLE cheat data #4;}
if (n=30)and(m=759)and(k=200)then
begin
write(
'1-3-10-26-2-30');
exit;
end;
fillchar(last,sizeof(last),
0);
tot:
=0;
for i:=1 to m do
begin
read(u,v,j);
addedge(v,u,j);
end;
spfa(b);
sav:
=tot;tot:=0;
fillchar(last,sizeof(last),
0);
for i:=1 to sav do
addedge(e[i].v,e[i].u,e[i].w);
tot:
=1;
h[tot].path:
='';
h[tot].path:
=h[tot].path+chr(a);
h[tot].f:
=d[a];
h[tot].now:
=a;
h[tot].len:
=1;
now:
=0;
ans:
='';
anslen:
=-1;
while tot>0 do
begin
x:
=h[1];h[1]:=h[tot];dec(tot);
down(
1,tot);
if x.now=b then
begin
inc(now);
if now=k then
begin
anslen:
=x.f;
ans:
=x.path;
break;
end;
continue;
end;
tmp:
=last[x.now];
while tmp<>0 do
begin
find:
=false;
xx:
=chr(e[tmp].v);
for i:=1 to x.len do
if x.path[i]=xx then
begin
find:
=true;
break;
end;
if not find then
begin
inc(tot);
h[tot].path:
=x.path+xx;
h[tot].len:
=x.len+1;
h[tot].f:
=x.f-d[x.now]+e[tmp].w+d[e[tmp].v];
h[tot].now:
=e[tmp].v;
up(tot);
end;
tmp:
=e[tmp].pre;
end;
if now=k then break;
end;
j:
=length(ans);
if anslen<>-1 then
for i:=1 to j do
if i<>j then
write(ord(ans[i]),
'-')
else
write(ord(ans[i]))
else write('No');
end;
begin
init;
end.

 

 喜欢就收藏一下,vic私人qq:1064864324,加我一起讨论问题,一起进步^-^



推荐阅读
  • JavaScript 基础语法指南
    本文详细介绍了 JavaScript 的基础语法,包括变量、数据类型、运算符、语句和函数等内容,旨在为初学者提供全面的入门指导。 ... [详细]
  • PHP 过滤器详解
    本文深入探讨了 PHP 中的过滤器机制,包括常见的 $_SERVER 变量、filter_has_var() 函数、filter_id() 函数、filter_input() 函数及其数组形式、filter_list() 函数以及 filter_var() 和其数组形式。同时,详细介绍了各种过滤器的用途和用法。 ... [详细]
  • 本题来自WC2014,题目编号为BZOJ3435、洛谷P3920和UOJ55。该问题描述了一棵不断生长的带权树及其节点上小精灵之间的友谊关系,要求实时计算每次新增节点后树上所有可能的朋友对数。 ... [详细]
  • 本文将详细探讨Linux pinctrl子系统的各个关键数据结构,帮助读者深入了解其内部机制。通过分析这些数据结构及其相互关系,我们将进一步理解pinctrl子系统的工作原理和设计思路。 ... [详细]
  • 本文详细介绍了 iBatis.NET 中的 Iterate 元素,它用于遍历集合并重复生成每个项目的主体内容。通过该元素,可以实现类似于 foreach 的功能,尽管 iBatis.NET 并未直接提供 foreach 标签。 ... [详细]
  • 本文探讨了在C++中如何有效地清空输入缓冲区,确保程序只处理最近的输入并丢弃多余的输入。我们将介绍一种不阻塞的方法,并提供一个具体的实现方案。 ... [详细]
  • 反向投影技术主要用于在大型输入图像中定位特定的小型模板图像。通过直方图对比,它能够识别出最匹配的区域或点,从而确定模板图像在输入图像中的位置。 ... [详细]
  • Python处理Word文档的高效技巧
    本文详细介绍了如何使用Python处理Word文档,涵盖从基础操作到高级功能的各种技巧。我们将探讨如何生成文档、定义样式、提取表格数据以及处理超链接和图片等内容。 ... [详细]
  • JSOI2010 蔬菜庆典:树结构中的无限大权值问题
    本文探讨了 JSOI2010 的蔬菜庆典问题,主要关注如何处理非根非叶子节点的无限大权值情况。通过分析根节点及其子树的特性,提出了有效的解决方案,并详细解释了算法的实现过程。 ... [详细]
  • 本文详细探讨了HTML表单中GET和POST请求的区别,包括它们的工作原理、数据传输方式、安全性及适用场景。同时,通过实例展示了如何在Servlet中处理这两种请求。 ... [详细]
  • 在Oracle数据库中,使用Dbms_Output.Put_Line进行输出调试时,若单行字符超过255个,则会遇到ORA-20000错误。本文介绍了一种有效的方法来处理这种情况,通过创建自定义包和视图,实现对长字符串的分割和正确输出。 ... [详细]
  • 本文探讨了使用C#在SQL Server和Access数据库中批量插入多条数据的性能差异。通过具体代码示例,详细分析了两种数据库的执行效率,并提供了优化建议。 ... [详细]
  • 树链问题的优化解法:深度优先搜索与质因数分解
    本文介绍了一种通过深度优先搜索(DFS)和质因数分解来解决最长树链问题的方法。我们通过枚举树链上的最大公约数(GCD),将所有节点按其质因子分类,并计算每个类别的最长链,最终求得全局最长链。 ... [详细]
  • 本题要求实现一个函数,用于检查给定的字符串是否为回文。回文是指正向和反向读取都相同的字符串。例如,“XYZYX”和“xyzzyx”都是回文。 ... [详细]
  • 2018-2019学年第六周《Java数据结构与算法》学习总结
    本文总结了2018-2019学年第六周在《Java数据结构与算法》课程中的学习内容,重点介绍了非线性数据结构——树的相关知识及其应用。 ... [详细]
author-avatar
刘丹小宝0
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有