第一问dfs不说

第二问很容易让人想到最小树形图,但是我不会,而且时间复杂度也不允许

还有什么不同的方法呢?

首先想到的是prim的思想,设根节点已经确定,其他点未确定

我们就不断从已确定的点延伸,找到到未确定点中高度最高的那个点的最短边距(如果有多个高度相同的点,肯定选边距最短的)

将边距加入ans,并将这个点标为确定,重复上述,知道所有点都确定即可。

这样的算法没有问题,但是复杂度好像仍然不能AC

我们想,既然我们能用类似prim的思想,为什么不用Kruska呢?

Kruskal的问题在于,这个算法是不涉及到边的方向,用这个不能选出符合条件的解

考虑之前我们用类似prim的思想解题的时候,是以点的高度为第一关键字,然后再以距离为第二关键字

在Kruskal对边排序的时候,我们是不是也可以考虑以点的高度为第一关键字,然后以距离为第二关键字排序呢?

就是这样,我们以边的终点高度为第一关键字降序,长度为第二关键字升序排序

然后按最小生成树的方法做就行了。

结果竟然TLE了,仔细对照一下别人的程序发现一直以来我的并查集写的是有问题的

我原来getfather是这么写的

function getf(x:longint):longint;

begin

while fa[x]<>x do x:=fa[x];

exit(x);

end;

而实际上多次调用这个函数,显然会进行很多冗余的运算

而正确的写法应该是

function getf(x:longint):longint;

begin

if fa[x]<>x then fa[x]:=getf(fa[x]);

exit(fa[x]);

end;

这应该才是并查集所谓反阿克曼函数的时间复杂度吧

亡羊补牢,为时不晚;

 type node=record
       x,c,y,next:longint;
     end; var a:array[..] of node;
    fa,p,q,h:array[..] of longint;
    v:array[..] of boolean;
    len,x,y,z,n,m,i,j,k1,k2,t:longint;
    ans,e:int64; procedure swap(var a,b:node);
  var c:node;
  begin
    c:=a;
    a:=b;
    b:=c;
  end; function getf(x:longint):longint;
  begin
    if fa[x]<>x then fa[x]:=getf(fa[x]); //唉
    exit(fa[x]);
  end; procedure add(x,y,z:longint);
  begin
    inc(len);
    a[len].y:=y;
    a[len].c:=z;
    a[len].x:=x;
    a[len].next:=p[x];
    p[x]:=len;
  end; procedure bfs;
  var i,f,x,y:longint;
  begin
    t:=;
    q[]:=;
    v[]:=true;
    f:=;
    while f<=t do
    begin
      x:=q[f];
      i:=p[x];
      while i<>- do
      begin
        y:=a[i].y;
        if not v[y] then
        begin
          v[y]:=true;
          inc(t);
          q[t]:=y;
        end;
        i:=a[i].next;
      end;
      inc(f);
    end;
  end; procedure sort(l,r:longint);
  var i,j,x,y,z:longint;
  begin
    i:=l;
    j:=r;
    x:=a[(l+r) shr ].c;
    y:=a[(l+r) shr ].y;
    repeat
      while (h[a[i].y]>h[y]) or (h[a[i].y]=h[y]) and (a[i].c<x) do inc(i);
      while (h[y]>h[a[j].y]) or (h[a[j].y]=h[y]) and (x<a[j].c) do dec(j);
      if not(i>j) then
      begin
        swap(a[i],a[j]);
        inc(i);
        j:=j-;
      end;
    until i>j;
    if l<j then sort(l,j);
    if i<r then sort(i,r);
  end; begin
  fillchar(p,sizeof(p),);
  readln(n,m);
  len:=;
  for i:= to n do
    read(h[i]);
  for i:= to m do
  begin
    readln(x,y,z);
    if h[x]>h[y] then add(x,y,z)
    else begin
      add(y,x,z);
      if h[x]=h[y] then add(x,y,z);
    end;
  end;
  bfs;
  sort(,len);
  for i:= to n do
    fa[i]:=i;
  i:=;
  j:=;
  for j:= to len do
  begin
    if not(v[a[j].x] and v[a[j].y]) then continue;  //首先必须是能访问到的点
    k1:=getf(a[j].x);
    k2:=getf(a[j].y);
    if k1<>k2 then
    begin
      fa[k2]:=k1;
      e:=a[j].c;
      ans:=ans+e;
      inc(i);
    end;
  end;
  writeln(t,' ',ans);
end.

bzoj2753的更多相关文章

  1. BZOJ2753 SCOI2012滑雪与时间胶囊(最小生成树)

    首先显然可以把所有能到的点拎出来建个新图,这样第一问也就做好了. 剩下的部分似乎是一个裸的最小树形图.但显然这个东西是没什么学的必要的并且不太能跑过去. 考虑建出来的图有什么性质.可以发现如果没有高度 ...

  2. BZOJ2753 SCOI2012 滑雪与时间胶囊 【最小生成树】*

    BZOJ2753 SCOI2012 滑雪与时间胶囊 Description a180285非常喜欢滑雪.他来到一座雪山,这里分布着M条供滑行的轨道和N个轨道之间的交点(同时也是景点),而且每个景点都有 ...

  3. BZOJ2753 [SCOI2012]滑雪与时间胶囊 【kruskal】

    题目链接 BZOJ2753 题解 完了我连\(kruskal\)裸题都做不出来了.. 题目是求最小树形图,即有向图最小生成树 我们不能直接上\(kruskal\),而要保证先加入前面的点, 所以我们排 ...

  4. Bzoj2753 [SCOI2012]滑雪与时间胶囊

    2753: [SCOI2012]滑雪与时间胶囊 Time Limit: 50 Sec  Memory Limit: 128 MBSubmit: 2282  Solved: 796 Descriptio ...

  5. [BZOJ2753][SCOI2012]滑雪与时间胶囊(特殊的有向树形图)

    题目:http://www.lydsy.com:808/JudgeOnline/problem.php?id=2753 分析: 第一问:直接BFS扩展知道无法扩展 第二问: 看似就是最小树形图啊= = ...

  6. bzoj2753[SCOI2012]滑雪与时间胶囊 最小生成树

    Time Limit: 50 Sec  Memory Limit: 128 MBSubmit: 2843  Solved: 993[Submit][Status][Discuss] Descripti ...

  7. 2019.01.17 bzoj2753: [SCOI2012]滑雪与时间胶囊(最小生成树)

    传送门 最小生成树菜题. 题意:给出一些有向边,问有向的最小生成树. 思路:先dfsdfsdfs一把所有有用的边都存起来,然后按终点点权为第一关键字,边权为第二关键字给边排序保证最小生成树的合法性,排 ...

  8. [BZOJ2753]滑雪与时间胶囊

    第一问直接把可以走的边连起来bfs一遍即可 第二问可以用类似kruskal的方法,只不过排序的依据应该变为第一关键字为终点高度(从大到小),第二关键字为边权(从小到大),只排序可以走的边 因为同样高度 ...

  9. 【bzoj2753】[SCOI2012]滑雪与时间胶囊

    #include<algorithm> #include<iostream> #include<cstdlib> #include<cstring> # ...

随机推荐

  1. SVN: revert all command

    If you accidentally marked all your files as "delete" (your file/folder has a red x on it) ...

  2. Custom Action : dynamic link library

    工具:VS2010, Installshield 2008 实现功能: 创建一个C++ win32 DLL的工程,MSI 工程需要调用这个DLL,并将Basic MSI工程中的两个参数,传递给DLL, ...

  3. Entity Framework 学习笔记(2)

    上期回顾:Entity Framework 学习笔记(1) Entity Framework最主要的东西,就是自己创建的.继承于DbContext的类: /// <summary> /// ...

  4. java 中hashcode和equals 总结

    一.概述            在Java中hashCode的实现总是伴随着equals,他们是紧密配合的,你要是自己设计了其中一个,就要设计另外一个.当然在多数情况下,这两个方法是不用我们考虑的,直 ...

  5. 安装eclipse中文汉化包后无法打开eclipse

    通过在线安装中文汉化包后一直提示无法启动程序在.log中查看日志 !SESSION 2016-01-15 11:22:57.959 ---------------------------------- ...

  6. Linux oracle数据库自动备份自动压缩脚本代码

    Linux oracle数据库备份完成后可以自动压缩脚本代码. 复制代码代码如下: #!/bin/bash #backup.sh #edit: www.jbxue.com ##系统名称 sysname ...

  7. opengl打开本地bmp图片绘制

    注意bmp图片的格式问题,32位ARGB  或者24位RGB.你所采用的素材一定要注意是多少位的就用多少位的.否则会显示错误的图片或者其他什么的错误. 代码如下 32位版本 #include < ...

  8. 2014年度辛星html教程夏季版第六节

    不知道这样大家会不会感觉枯燥,总之不管大家怎么样,辛星始终会陪伴大家的,期待您的关注和支持,也衷心的希望我的博客能让您少走弯路,获得更系统的知识. ***************表格********* ...

  9. CATransition的动画效果类型及实现方法--老代码备用参考

    实现iphone漂亮的动画效果主要有两种方法,一种是UIView层面的,一种是使用CATransition进行更低层次的控制, 第一种是UIView,UIView方式可能在低层也是使用CATransi ...

  10. HTTP错误 404.17

    HTTP错误 404.17 - Not Found" IIS 7.5 请求的内容似乎是脚本,因而将无法由静态文件处理程序来处理   出现这种情况的原因通常是因为先安装了Framework,后 ...