cf757G. Can Bash Save the Day?

题目要求处理一棵树上的节点距离查询与数组元素交换,通过将问题转化为持久化重心树来实现。询问操作可拆分为多个单点到区间的查询,使用重心树能快速求解距离和。通过特定算法将一般树转化为二叉树,降低复杂度到O(nlogn),空间复杂度为O(nlogn)。虽然空间需求较高,但能在给定时限内处理151个测试点。
摘要由CSDN通过智能技术生成

简述题意:给一棵n个节点的数和一个n的数组(n的排列),支持两个操作:1 询问a[l]~a[r]的所有点到某个点的距离,2 交换a[x]与a[x+1]。

一开始想到了这道题bzoj4012: [HNOI2015]开店,大概看了之后发现是开店的加强版。我想到像开店一样使用主席树处理,显然操作2很容易。然而

他的时间是一个log。大概看了题解,感觉套路~   毕竟开店的题解大多是log^2。。。


//以下来自翻译

对于询问l~r,可以拆成1~l-1,1~r的询问。想要询问一个点到一些点的距离和,可以在重心树(Centroid Tree)上直接跑。然后给出一个可持久化重心树(Persistent Centroid Tree),用与线段树类似的思路,维护当前区间的所有点数量 与到重心父亲的距离和,每加入一个节点只需要修改它在重心树上到root的距离。由于重心树深度是O(logn),所以直接可持久化每次是O(Σ重心树上儿子数),这显然是不优的。

然后就有了O(n)把一般树转换为O(n)节点的二叉树的算法,就是

### 回答1: .bashrc 文件是在每次打开终端时都会被执行的 shell 脚本文件。它用于设置环境变量、别名、命令补全等。 .bash_profile 文件是在用户登录时执行的 shell 脚本文件。它用于设置环境变量、别名、命令补全等。 总的来说,.bashrc 是在打开终端时执行的,而 .bash_profile 是在用户登录时执行的。 ### 回答2: 在Linux和Mac系统中,用户的配置文件通常存放在用户目录下的`.bashrc`和`.bash_profile`中。虽然它们具有相似的功能,但也有一些区别。 `.bashrc`是用户每次打开新的终端会话时会被加载的配置文件。它包含了一些适用于当前用户的环境变量、别名、函数和指令,以及一些用户自定义的命令行设置。它的作用是为当前用户的命令行环境提供一些个性化的配置。一些常见的设置可能包括修改命令行提示符、定义快捷命令和别名等。 `.bash_profile`是在用户登录时加载的配置文件。它会在用户第一次登录时执行一次,而不是在每次打开新的终端会话时执行。这个文件主要用于设置用户全局的环境变量和工作目录。例如,用户可以在这个文件中定义一些与登录有关的环境变量,如`$PATH`,`$HOME`和`$DISPLAY`等。此外,用户还可以在`.bash_profile`文件中执行一些需要在登录时运行的脚本。 由于区别是在于何时加载配置文件,所以通常在`.bash_profile`中会调用或加载`.bashrc`文件,以确保在登录时设置的环境变量和别名也能在每个新的终端会话中使用。 在大多数情况下,用户可以将命令行环境的个性化配置和用户全局环境变量的设置分别放在这两个文件中,以便根据需要进行修改。但有时两个文件的设置可能会重叠,这需要用户根据实际情况来判断在哪个文件中进行相应的配置。 综上所述,`.bashrc`和`.bash_profile`都是用于配置用户命令行环境和环境变量的文件,区别在于`.bashrc`会在每次打开新的终端时加载,而`.bash_profile`则在用户登录时加载。 ### 回答3: 在Linux系统中,用户目录下有两个重要的配置文件:.bashrc和.bash_profile,它们的作用是在用户登录到系统时自动加载一些环境变量和执行一些配置操作。不同之处如下: 1.位置不同:.bashrc位于用户的家目录下,而.bash_profile位于家目录之下的隐藏目录.bashrc中。 2.加载时机不同:.bashrc在每次打开一个新的终端窗口时,都会加载该文件中的配置;而.bash_profile在用户登录到系统时才会加载,只会执行一次。 3.用途不同:.bashrc主要用于存放一些与交互式终端相关的配置和环境变量,比如设置别名、自定义命令等;而.bash_profile主要用于存放一些与登录会话相关的配置和环境变量,比如添加环境变量、执行一些初始化操作等。 4.调用关系不同:在用户登录时,系统会首先加载.bash_profile文件,然后再加载.bashrc文件。 需要注意的是,由于不同Linux发行版的默认配置可能有所不同,所以有些系统可能会将.bashrc和.bash_profile的加载行为互换,也有些系统会在.bash_profile中直接调用.bashrc,以确保两者的配置都能生效。 总而言之,.bashrc和.bash_profile是用于自定义和配置用户登录会话、交互式终端的环境变量和操作的文件,它们的区别在于加载时机、用途和调用关系,并且需要根据具体的操作系统来进行配置。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值