第7章 排序

前言

        在这一章,我们讨论数组元素的排序问题。为简单起见,假设在我们的例子中数组只包含整数,虽然更复杂的结构显然也是可能的。对于本章的大部分内容,我们还假设整个排序工作能够在主存中完成,因此,元素的个数相对来说比较小(小于\mathit{10^{6}})。当然,不能在主存中完成而必须在磁盘或磁带上完成的排序也相当重要。这种类型的排序叫作外部排序(external sorting),将在本章末尾讨论外部排序。

        我们对内部排序的考察将指出:

  • 存在几种容易的算法以\mathit{O(N^{2})}排序,如插入排序。
  • 有一种算法叫作希尔排序(Shellsort),它的编程非常简单,以\mathit{o(N^{2})}运行,并在实践中很有效。
  • 有一些稍微复杂的\mathit{O(NlogN)}的排序算法。
  • 任何通用的排序算法均需要\mathit{\Omega (NlogN)}次比较。

        本章的其余部分将描述和分析各种排序算法。这些算法包含一些有趣的、重要的代码优化和算法设计思想。可以对排序做出精确的分析。预先说明,在适当的时候,我们将尽可能地多做一些分析。

7.1 预备知识

        我们描述的算法都将是可以互换的。每个算法都将接收一个含有元素的数组和一个包
含元素个数的整数。

        我们将假设\mathit{N}是传递到排序例程中的元素个数,它已经被检查过,是合法的。按照C
的约定,对于所有的排序,数据都将在位置0处开始。

        我们还假设“<”和“>”运算符存在,它们可以用于对输入进行一致的排序。除赋
值运算符外,这两种运算是仅有的允许对输入数据进行的操作。在这些条件下的排序叫作
基于比较的排序(comparison-based sorting)。

7.2 插入排序

7.2.1 算法

        最简单的排序算法之一是插入排序(insertion sort)。插入排序由\mathit{N-1}趟(pass)排序组成。对于\mathit{P=1}趟到\mathit{P=N-1}趟,插入排序保证从位置0到位置\mathit{P}上的元素为已排序状态。插入排序利用了这样的事实:位置0到位置\mathit{P-1}上的元素是已排过序的。图7-1显示一个简单的数组在每一趟插入排序后的情况。

        图7-1表达了一般的方法。在第\mathit{P}趟,我们将位置\mathit{P}上的元素向左移动到它在前\mathit{P+1}个元素中的正确位置上。图7-2中的程序实现该想法。第2~5行实现数据移动而没有明显使用交换。将位置\mathit{P}上的元素存于Tmp中,而(在位置\mathit{P}之前)所有更大的元素都向右移动一个位置。然后将Tmp置于正确的位置上。这种方法与实现二叉堆时所用到的技巧相同。

void InsertionSort(ElementType A[], int N)
{int j, P;ElementType Tmp;for (P = 1; P < N; P++){Tmp = A[P];for (j = P; j > 0 && A[j - 1] > Tmp; j--)A[j] = A[j - 1];A[j] = Tmp;}
}

7.2.2 插入排序的分析

        由于嵌套循环每趟花费N次迭代,因此插入排序为\mathit{O(N^{2})},而且这个界是精确的,因为以反序输入可以达到该界。精确计算指出对于\mathit{P}的每一个值,第4行的测试最多执行\mathit{P+1}次。对所有的\mathit{P}求和,得到总数为

\sum_{i=2}^{N}i=2+3+4+\cdot \cdot \cdot +N=\Theta (N^{2})

        另一方面,如果输入数据已预先排序,那么运行时间为\mathit{O(N)},因为内层for循环的检测总是立即判定不成立而终止。事实上,如果输入几乎已排序(该术语将在下一节更严格地定义),那么插入排序将运行得很快。由于这种变化差别很大,因此值得我们去分析该算法平均情形的行为。实际上,和各种其他排序算法一样,插入排序的平均情形也是\Theta (N^{2}),详见下节的分析。

7.3 一些简单排序算法的下界

        数字数组的一个逆序(inversion)是指数组中具有\mathit{i<j}\mathit{A[i]>A[j]}的序偶(\mathit{A[i],A[j]})。在上节的例子中,输入数据34,8,64,51,32,21有9个逆序,即(34,8),(34,32),(34,21),(64,51),(64,32),(64,21),(51,32),(51,21),(32,21)。这正好是需要由插入排序(非直接)执行的交换次数。情况总是这样,因为交换两个不按原序排列的相邻元素恰好消除一个逆序,而一个排过序的数组没有逆序。由于算法中还有\mathit{O(N)}项其他的工作,因此插入排序的运行时间是\mathit{O(I+N)},其中\mathit{I}为原始数组中的逆序数。于是,若逆序数是\mathit{O(N)},则插入排序以线性时间运行。

        我们可以通过计算排列中的平均逆序数而得出插入排序平均运行时间的精确的界。如往常一样,定义平均是一个困难的命题。我们将假设不存在重复元素(如果允许重复,那么我们甚至连重复的平均次数究竟是什么都不清楚)。利用该假设,我们可设输入数据是前\mathit{N}个整数的某个排列(因为只有相对顺序才是重要的),并设所有的排列都是等可能的。在这些假设下,我们有如下定理:

        定理 7.1 \mathit{N}个互异数的数组的平均逆序数是\mathit{N(N-1)/4}

        证明:对于含有任意的数的表\mathit{L},考虑其反序表\mathit{L_{r}}。上例中的反序表是21,32,51,64,8,34。考虑该表中任意两个数的序偶(x,y),且y>x。显然,恰是\mathit{L}\mathit{L_{r}}之中的一个,该序偶表示一个逆序。在表\mathit{L}和它的反序表\mathit{L_{r}},中序偶的总个数为\mathit{N(N-1)/2}。因此,平均表有该量的一半,即\mathit{N(N-1)/4}个逆序。

        这个定理意味着插入排序平均是二次的,同时也提供了只交换相邻元素的任何算法的一个很强的下界。

        定理 7.2 通过交换相邻元素进行排序的任何算法平均需要\mathit{\Omega (N^{2})}时间。

        证明:初始的平均逆序数 是\mathit{N(N-1)/4=\Omega (N^{2})},而每次交换只减少一个逆序,因此需要\mathit{\Omega (N^{2})}次交换。

        这是证明下界的一个例子,它不仅对非显式地实施相邻元素的交换的插入排序有效,而且对诸如冒泡排序和选择排序等其他一些简单算法也是有效的,不过这些算法将不在这里描述。事实上,它对一整类只进行相邻元素的交换的排序算法(包括那些未被发现的算法)都是有效的。正因为如此,这个证明在经验上是不能被认可的。虽然这个下界的证明非常简单,但是一般说来证明下界要比证明上界复杂得多。

        这个下界告诉我们,为了使一个排序算法以亚二次(subquadratic)或\mathit{o (N^{2})}时间运行,必须执行一些比较,特别要对相距较远的元素进行交换。一个排序算法通过删除逆序得以向前进行,而为了有效地运行,它必须每次交换删除不止一个逆序。

7.4 希尔排序

        希尔排序(Shellsort)的名称源于它的发明者Donald Shell,该算法是冲破二次时间屏障的第一批算法之一,不过,从它的发现之日起,又过了若干年后才证明了它的亚二次时间界。正如上节所提到的,它通过比较相距一定间隔的元素来工作,各趟比较所用的距离随着算法的进行而减小,直到只比较相邻元素的最后一趟排序为止。由于这个原因,希尔排序有时也叫作缩小增量排序(diminishing increment sort)。

        希尔排序使用一个序列\mathit{h_{1},h_{2},\cdot \cdot \cdot ,h_{t}}叫作增量序列(increment sequence)。只要\mathit{h_{1}=1},任何增量序列都是可行的,不过,有些增量序列比另外一些增量序列更好(后面我们将讨论这个问题)。在使用增量\mathit{h_{k}}的一趟排序之后,对于每一个\mathit{i}我们有\mathit{A[i]\leqslant A[i+h_{k}]}(这里它是有意义的),所有相隔\mathit{h_{k}}的元素都被排序。此时称文件是\mathit{h_{k}}-排序的(\mathit{h_{k}}-sorted)。例如,图7-3显示了各趟排序后数组的情况。希尔排序的一个重要性质(我们只叙述而不证明)是一个\mathit{h_{k}}-排序的文件(此后将是\mathit{h_{k-1}}-排序的)保持它的\mathit{h_{k}}-排序性。事实上,假如情况不是这样的话,那么该算法也就没什么意义了,因为前面各趟排序的结果会被后面各趟排序给打乱。

        \mathit{h_{k}}-排序的一般做法是,对于\mathit{h_{k},h_{k}+1,\cdot \cdot \cdot ,N-1}中的每一个位置\mathit{i},把其上的元素放到\mathit{i,i-h_{k},i-2h_{k}\cdot \cdot \cdot }中间的正确位置上。虽然这并不影响最终结果,但是仔细的考察指出,一趟\mathit{h_{k}}-排序的作用就是对\mathit{h_{k}}个独立的子数组执行一次插入排序。当我们分析希尔排序的运行时间时,这个考察结果将是很重要的。

        增量序列的一种流行(但是不好)的选择是使用Shell建议的序列:\mathit{h_{t}=[N/2]}\mathit{h_{k}=[h_{k+1}/2]}图7-4包含一个使用该序列实现希尔排序的程序。后面我们将看到,存在一些递增的序列,它们对该算法的运行时间做出了重要的改进,即使是一个小的改变都可能剧烈地影响算法的性能。

void ShellSort(ElementType A[], int N)
{int i, j, Increment;ElementType Tmp;for (Increment = N / 2; Increment > 0; Increment /= 2)for(i = Increment; i < N; i++){Tmp = A[i];for (j = i; j >= Increment; j -= Increment)if(Tmp < A[j - Increment])A[j] = A[j - Increment];elsebreak;A[j] = Tmp;}
}

希尔排序的最坏情形分析

        虽然希尔排序编程简单,但是,其运行时间的分析则完全是另外一回事。希尔排序的运行时间依赖于增量序列的选择,而证明可能相当复杂。希尔排序的平均情形分析,除最平凡的一些增量序列外,是一个长期未解决的问题。我们将证明在两个特别的增量序列下最坏情形的精确的界。

        定理 7.3 使用希尔增量时希尔排序的最坏情形运行时间为\Theta (N^{2})

        证明:证明不仅需要指出最坏情形运行时间的上界,而且还需要指出存在某个输入实际上就花费\Omega (N^{2})时间运行。首先通过构造一个坏情形来证明下界。我们先选择\mathit{N}是2的幂。这使得除最后一个增量是1外所有的增量都是偶数。现在,我们给出一个数组Input-Data作为输入,它的偶数位置上有\mathit{N/2}个同为最大的数,而在奇数位置上有\mathit{N/2}个同为最小的数(对该证明,第一个位置是位置1)。由于除最后一个增量外所有的增量都是偶数,因此,当我们进行最后一趟排序前,\mathit{N/2}个最大的元素仍然处在偶数位置上,而\mathit{N/2}个最小的元素也还是在奇数位置上。于是,在最后一趟排序开始之前第\mathit{i}个最小的数(\mathit{i\leqslant N/2})在位置\mathit{2i-1}上。将第\mathit{i}个元素恢复到其正确位置需要在数组中移动\mathit{i-1}个间隔。这样,仅仅将\mathit{N/2}个最小的元素放到正确的位置上就至少需要\sum_{i=1}^{N/2}i-1=\Omega (N^{2})的工作。举一个例子,图7-5显示一个\mathit{N=16}时的坏(但不是最坏)的输入。在2-排序后的逆序数一直恰好保持为1+2+3+4+5+6+7=28,因此,最后一趟排序将花费相当多的时间。

        现在我们证明上界\mathit{O(N^{2})}以结束本证明。前面已经观察到,带有增量\mathit{h_{k}}的一趟排序由\mathit{h_{k}}个关于\mathit{N/h_{k}}个元素的插入排序组成。由于插入排序是二次的,因此一趟排序总的开销是\mathit{O(h_{k}(N/h_{k})^{2})=O(N^{2}/h_{k})}。对所有各趟排序求和则给出总的界为\mathit{O(\sum_{i=1}^{t}N^{2}/h_{i})=O(N^{2}\sum_{i=1}^{t}1/h_{k})}。因为这些增量形成一个几何级数,其公比为2,而该级数中的最大项是
\mathit{h_{1}=1},因此,\mathit{\sum_{i=1}^{t}1/h_{i}<2}。于是,我们得到总的界\mathit{O(N^{2})}

        希尔增量的问题在于,这些增量对未必互素,因此较小的增量可能影响很小。Hibbard提出一个稍微不同的增量序列,它在实践中(并且理论上)给出更好的结果。他的增量形如\mathit{1,3,7,\cdot \cdot \cdot ,2^{k}-1}。虽然这些增量几乎是相同的,但关键的区别是相邻的增量没有公因子。现在我们就来分析使用这个增量序列的希尔排序的最坏情形运行时间,这个证明相当复杂。

        定理 7.4 使用Hibbard增量的希尔排序的最坏情形运行时间为\mathit{\Theta (N^{3/2})}

        证明:我们只证明上界而将下界的证明留作练习。这个证明需要堆垒数论(additivenumber theory)中某些众所周知的结果。本章末提供了这些结果的参考资料。

        和前面一样,对于上界,我们还是计算每一趟排序的运行时间的界,然后对各趟求和。对于那些\mathit{h_{k}>N^{1/2}}的增量,我们将使用前一定理得到的界\mathit{O(N^{2}/h_{k})}。虽然这个界对于其他增量也是成立的,但是它太大,用不上。直观地看,我们必须利用这个增量序列是特殊的这样一个事实。我们需要证明的是,对于位置\mathit{P}上的任意元素\mathit{A_{p}},当要执行\mathit{h_{k}}-排序时,只有少数元素在位置\mathit{P}的左边且大于\mathit{A_{p}}

        当对输入数组进行\mathit{h_{k}}-排序时,我们知道它已经是\mathit{h_{k+1}}-排序和\mathit{h_{k+2}}-排序的了。在\mathit{h_{k}}-排序以前,考虑位置\mathit{P}\mathit{P-i}上的两个元素,其中\mathit{i\leqslant P}。如果\mathit{i}\mathit{h_{k+1}}\mathit{h_{k+2}}的倍数,那么显然\mathit{A[P-i]<A[P]}。不仅如此,如果\mathit{i}可以表示为\mathit{h_{k+1}}\mathit{h_{k+2}}的线性组合(以非负整数的形式),那么也有\mathit{A[P-i]<A[P]}。例如,当我们进行3-排序时,文件已经是7-排序和
15-排序的了。52可以表示为7和15的线性组合:52=1×7+3×15。因此,A[100]不可能大于A[152],因为\mathit{A[100]\leqslant A[107]\leqslant A[122]\leqslant A[137]\leqslant A[152]}

        现在,\mathit{h_{k+2}=2h_{k+1}+1},因此\mathit{h_{k+1}}\mathit{h_{k+2}}没有公因子。在这种情形下,可以证明,至少和\mathit{(h_{k+1}-1)(h_{k+2}-1)=8h_{k}^{2}+4h_{k}}一样大的所有整数都可以表示为\mathit{h_{k+1}}\mathit{h_{k+2}}的线性组合(见本章末尾的参考文献)。

        这就告诉我们,第4行的for循环体对于这些\mathit{N-h_{k}}位置上的每一个,最多执行\mathit{8h_{k}+4=O(h_{k})}次。于是我们得到每趟的界\mathit{O(Nh_{k})}

        利用大约一半的增量满足\mathit{h_{k}<\sqrt{N}}的事实并假设\mathit{t}是偶数,那么总的运行时间为
\mathit{O(\sum_{k+1}^{t/2}Nh_{k}+\sum_{k=t/2+1}^{t}N^{2}/h_{k})=O(N\sum_{k=1}^{t/2}h_{k}+N^{2}\sum_{k=t/2+1}^{t}1/h_{k})}
因为两个和都是几何级数,并且\mathit{h_{t/2}=\Theta (\sqrt{N})},所以上式简化为
\mathit{=O(Nh_{t/2})+O(\frac{N^{2}}{h_{t/2}})=O(N^{3/2})}

        使用Hibbard增量的希尔排序平均情形运行时间基于模拟的结果被认为是\mathit{O(N^{5/4})},但是没有人能够证明该结果。Pratt已经证明,\mathit{\Theta (N^{3/2})}的界适用于广泛的增量序列。

        Sedgewick 提出了几种增量序列,其最坏情形运行时间(也是可以达到的)为\mathit{O(N^{4/3})}。对于这些增量序列的平均运行时间猜测为\mathit{O(N^{7/6})}。经验研究指出,在实践中这些序列的运行要比Hibbard的好得多,其中最好的是序列(1,5,19,41,109,...),该序列中的项或者是\mathit{9\cdot 4^{i}-9\cdot 2^{i}+1},或者是\mathit{4^{i}-3\cdot 2^{i}+1}。通过将这些值放到一个数组中可以最容易地实现该算法。虽然有可能存在某个增量序列使得能够对希尔排序的运行时间做出重大改进,但是,这个增量在实践中还是最为人们称道的。

        关于希尔排序还有几个其他结果,它们需要数论和组合数学中一些艰深的定理而且主要是在理论上有用。希尔排序是算法非常简单又具有极其复杂的分析的一个好例子。

        希尔排序的性能在实践中是完全可以接受的,即使是对于数以万计的\mathit{N}仍是如此。编程的简单特点使得它成为对较大的输入数据经常选用的算法。

7.5 堆排序

7.6 归并排序

7.7 快速排序

7.7.1 选取枢纽元

7.7.2 分割策略

7.7.3 小数组

7.7.4 实际的快速排序例程

7.7.5 快速排序的分析

7.7.6 选择的线性期望时间算法

7.8 大型结构的排序

7.9 排序的一般下界

7.10 桶式排序

7.11 外部排序

7.11.1 为什么需要新的算法

7.11.2 外部排序模型

7.11.3 简单算法

7.11.4 多路合并

7.11.5 多相合并

7.11.6 替换选择

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/229299.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

计算机网络知识点

计算机网络中的OSI模型 OSI模型是指“国际标准化组织(SO)”提出的使各种计算机在世界范围内互通互联的网络标准框架简称开放系统互联参考模型 (OSI)。 七层模型&#xff1a;应用层、表示层、会话层、传输层、网络层&#xff08;IP协议、RARP协议、ARP协议、CIDR协议&#xff0…

kafka学习笔记--Topic 数据的存储机制

本文内容来自尚硅谷B站公开教学视频&#xff0c;仅做个人总结、学习、复习使用&#xff0c;任何对此文章的引用&#xff0c;应当说明源出处为尚硅谷&#xff0c;不得用于商业用途。 如有侵权、联系速删 视频教程链接&#xff1a;【尚硅谷】Kafka3.x教程&#xff08;从入门到调优…

docker小白第五天

docker小白第五天 docker的私有库 有些涉密的信息代码不能放在阿里云的镜像仓库&#xff0c;因此需要构建一个个人内网专属的私有库&#xff0c;将镜像或者容器代码进行推送保存。 下载镜像docker registry 执行代码docker pull registry&#xff0c;用于搭建私服前的准备。…

Linux系统log日志简单清理

系统空间告急 清理log日志 找出当前目录中文件最大的10个文件&#xff1a; cd /var/log du -s ./* | sort -nr | head 系统日志log文件&#xff1a; ll -h /var/log/journal 只保留100MB的日志 journalctl --vacuum-size100M 系统暴力爆破SSH日志&#xff1a; ll -h /var/lo…

初级数据结构(六)——堆

文中代码源文件已上传&#xff1a;数据结构源码 <-上一篇 初级数据结构&#xff08;五&#xff09;——树和二叉树的概念 | NULL 下一篇-> 1、堆的特性 1.1、定义 堆结构属于完全二叉树的范畴&#xff0c;除了满足完全二叉树的限制之外&#xff0c;还满…

SolidWorks二次开发 C#-读取基于Excel的BOM表信息

SolidWorks二次开发 C#-读取基于Excel的BOM表信息 问题点来源解决方案及思路相关引用链接 问题点来源 这是一位粉丝问的一个问题&#xff0c;他说到: 老师&#xff0c;请问Solidworks二次开发工程图中"基于Excel的材料明细表"怎么读取里面的数据&#xff1f; Ps:这…

leetcode刷题日志-383赎金信

思路&#xff1a;分别用两个map记录ransomNote和magazine中的字符以及出现的次数。最后遍历记录ransomNote的map&#xff0c;如果ransomNote的map中出现的magazine的map中没有出现或者出现的次数小于ransomNote的map则返回false&#xff0c;否则返回true&#xff1b; class So…

arcgis api for js 图层标注文本不显示

在打包arcgis api for js 项目后&#xff0c;更新到现场所有地图文本要素不显示的时候。 可能就是环境设置问题了&#xff0c;需要配置iis或者ngixs里边配置如下类型 iis发布的项目 1、打开iis中发布的网站 2、找到网站的MIME类型如下图 3、添加一下类型&#xff08;一个都不…

机器学习项目精选 第一期:超完整数据科学资料合集

大噶吼&#xff0c;不说废话&#xff0c;分享一波我最近看过并觉得非常硬核的资源&#xff0c;包括Python、机器学习、深度学习、大模型等等。 1、超完整数据科学资料合集 地址&#xff1a;https://github.com/krishnaik06/The-Grand-Complete-Data-Science-Materials Pytho…

【Linux API 揭秘】container_of函数详解

我的圈子&#xff1a; 高级工程师聚集地 我是董哥&#xff0c;高级嵌入式软件开发工程师&#xff0c;从事嵌入式Linux驱动开发和系统开发&#xff0c;曾就职于世界500强企业&#xff01; 创作理念&#xff1a;专注分享高质量嵌入式文章&#xff0c;让大家读有所得&#xff01; …

1852_bash中的find应用扩展

Grey 全部学习内容汇总&#xff1a; https://github.com/GreyZhang/toolbox 1852_bash中的find应用扩展 find这个工具我用了好多年了&#xff0c;但是是不是真的会用呢&#xff1f;其实不然&#xff0c;否则也不会出现这种总结式的笔记。其实&#xff0c;注意部分小细节之后…

liunx之Samba服务器

环境&#xff1a;虚拟机CENTOS 7和 测试机相通 一、Samba服务器_光盘共享&#xff08;匿名访问&#xff09; 1.在虚拟机CENTOS 7安装smb服务&#xff0c;并在防火墙上允许samba流量通过 2. 挂载光盘 3.修改smb.conf配置文件&#xff0c;实现光盘匿名共享 4. 启动smb服务 5.在…

手麻、腿麻、麻痛…背后竟隐藏7大疾病!多一个人知道,少一个悲剧!

手脚麻木背后的7大病症&#xff1a;骨病、脑梗、肿瘤…… 1、神经问题 上图四只手上橙色的区域代表了麻木感&#xff0c;如果您的手麻集中在无名指和小指的区域&#xff0c;您可以拿一张纸&#xff0c;用五个手指分别试着夹住&#xff0c;检验您的五个手指力量&#xff1b;您还…

(5)shell命令以及Linux的权限

写在前面 本章我们将重点讲解 Linux 权限&#xff0c;这是 Linux 基础部分中非常重要的一部分。内容比较干&#xff0c;我会稍稍正经些去讲解。话不多说&#xff0c;我们直接切入正题。 shell 命令及运行原理 严格意义上说的是一个操作系统&#xff0c;我们称之为 —— &…

Logstash访问安全访问Elasticsearch集群

生成logstash证书: opensal pkcs12 -in elastic-stack-ca.p12 -clcerts -nokeys > logafash.cer openssl x509 -in logstash.cer -out logstash.pem 编排配置文件

xtu oj 1328 数码和

题目描述 一个10进制数n在2∼16进制下可以得到的不同的数码和&#xff0c;求在这些数码和中出现次数最多的数码和。 比如20&#xff0c; 其中数码和2和4分别出现了3次&#xff0c;为最多出现次数。 输入 第一行是一个整数T(1≤T≤1000)&#xff0c;表示样例的个数。 以后每行…

Sherlock:社交媒体账号搜索工具 | 开源日报 No.111

sherlock-project/sherlock Stars: 45.1k License: MIT 这个项目是一个社交媒体账号搜索工具&#xff0c;名为 Sherlock。它可以通过用户名在不同的社交网络上追踪用户的账号。 支持单个或多个用户搜索提供 Docker 容器化部署方式开放源代码并欢迎贡献者参与开发包含详细测试…

Shell三剑客:sed(命令)一

一、删除命令&#xff1a;d [rootlocalhost ~]# sed -r /root/d passwd.txt bin:x:1:1:bin:/bin:/sbin/nologin daemon:x:2:2:daemon:/sbin:/sbin/nologin adm:x:3:4:adm:/var/adm:/sbin/nologin lp:x:4:7:lp:/var/spool/lpd:/sbin/nologin sync:x:5:0:sync:/sbin:/bin/sync…

Vim入门

Vim使用入门 1.Vim编辑器的三种常用模式 一般模式&#xff1a;刚打开文件是它&#xff0c;从编辑模式按“ESC”退回的模式也是它。可以执行各种编辑操作&#xff0c;如移动光标、复制、粘贴、删除、查找替换等 ; 编辑模式&#xff1a;在一般模式下按下 i、I、a、A、o、O 等键…

CesiumLab地理信息基础数据处理平台 各类数据类型介绍、发布数据介绍

目录 0 引言1 CesiumLab2 数据处理模块2.1 输出格式&#xff1a;切片文件格式2.2 输入格式2.2.1 传统GIS数据2.2.2 人工模型2.2.3 BIM模型2.2.4 倾斜实景数据2.2.5 点云数据 3 发布服务功能3.1 拓展&#xff1a;其他平台发布服务功能 &#x1f64b;‍♂️ 作者&#xff1a;海码…