30. 使用LotusScript排序

2024-02-01 18:58
文章标签 使用 排序 30 lotusscript

本文主要是介绍30. 使用LotusScript排序,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

排序是计算机编程中最常见的任务之一,排序算法也是最基本和常用的算法。存在许多种排序算法,它们的效率和复杂性各不相同。在LotusNotes中,公式语言里有@Sort函数,对List排序。LotusScript里没有类似的可以用作容器的数据结构,也就没有提供针对它们的排序功能。另外,使用LotusScript开发时,主要的数据对象是NotesDocument,而它们的排序都已经在视图里完成了,所以需要排序的情况并不多。但是有时候,我们也会遇到排序的需求,比如针对列表字段里的多值或是没有存在于文档中的数据。这时就需要我们在LotusScript里实现排序算法。这并不是特别困难的事,不过如果你想省事(像我一样),也可以使用现成的代码,比如下面的这几个用于排序的函数就来自于LotusNotes自带的模版数据库:

Public Function QuickSort(sArray As Variant) As VariantDim sA() As String    Dim j As LongDim bottom As LongDim top As LongDim vA As Variantbottom = LBound ( sArray )top = UBound ( sArray )ReDim sA( bottom To top ) As String     For j = bottom To topsA ( j ) = sArray ( j )Next' DoQS does a QuickSort if the Sublist is longer than 10 elements' Thus, when DoQS finishes, all elements are within 10 spots of their correct location.' For lists that are close to being in order, an Insertion Sort is much faster than a QuickSort, so we' run through the whole thing once doing an Insertion Sort to finish tidying up the order.Call DoQS( sA, bottom, top )Call DoInsertSort ( sA, bottom, top )ReDim vA(bottom To top) As VariantFor j = bottom To topvA ( j ) = sA ( j )Next	QuickSort = vA
End Function
Sub DoInsertSort ( sA() As String, ByVal bottom As Long, ByVal top As Long )	Dim i As LongDim x As LongDim v As StringDim Found As IntegerFor i = bottom+1 To topx = iv = sA (i )Do While (sA(x-1) > v)sA ( x ) = sA ( x-1 )x = x - 1If x=0 ThenExit DoEnd IfLoopsA (x) = vNext
End Sub
Sub DoQS( sA() As String, bottom As Long, top As Long )' Called by QuickSortDim length As LongDim i As LongDim j As LongDim Pivot As LongDim PivotValue As StringDim t As StringDim LastSmall As Longlength = top - bottom + 1' Only do the QuickSort if the sublist is at least 10 items longIf length > 10 Then' Pivot is chosen approx. halfway through sublist.' This gives us best speed if list is almost sorted already, and is no worse than any' other choice if the list is in random order.Pivot = bottom + (length \ 2)   ' Move PivotValue out of the wayPivotValue = sA( Pivot )sA ( Pivot ) = sA ( bottom )sA ( bottom ) = PivotValue' LastSmall is the location of the last value smaller than PivotValueLastSmall = bottomFor i = bottom + 1 To top If sA ( i ) < PivotValue Then LastSmall = LastSmall + 1t = sA ( i )sA ( i ) = sA ( LastSmall )sA ( LastSmall ) = tEnd IfNext' Move the PivotValue backt = sA ( LastSmall )sA ( LastSmall ) = sA ( bottom )sA ( bottom ) = tPivot = LastSmall' Now sort each sideCall DoQS ( sA, bottom, Pivot - 1 )Call DoQS ( sA, Pivot + 1, top )End IfEnd Sub

只需要调用QuickSort函数,它会对参数中的数组排序然后返回。它根据数组的大小采用快速排序和插入排序两种不同的算法。

这篇关于30. 使用LotusScript排序的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/668163

相关文章

C++快速排序超详细讲解

《C++快速排序超详细讲解》快速排序是一种高效的排序算法,通过分治法将数组划分为两部分,递归排序,直到整个数组有序,通过代码解析和示例,详细解释了快速排序的工作原理和实现过程,需要的朋友可以参考下... 目录一、快速排序原理二、快速排序标准代码三、代码解析四、使用while循环的快速排序1.代码代码1.由快

使用EasyExcel实现简单的Excel表格解析操作

《使用EasyExcel实现简单的Excel表格解析操作》:本文主要介绍如何使用EasyExcel完成简单的表格解析操作,同时实现了大量数据情况下数据的分次批量入库,并记录每条数据入库的状态,感兴... 目录前言固定模板及表数据格式的解析实现Excel模板内容对应的实体类实现AnalysisEventLis

使用国内镜像源优化pip install下载的方法步骤

《使用国内镜像源优化pipinstall下载的方法步骤》在Python开发中,pip是一个不可或缺的工具,用于安装和管理Python包,然而,由于默认的PyPI服务器位于国外,国内用户在安装依赖时可... 目录引言1. 为什么需要国内镜像源?2. 常用的国内镜像源3. 临时使用国内镜像源4. 永久配置国内镜

Go语言中最便捷的http请求包resty的使用详解

《Go语言中最便捷的http请求包resty的使用详解》go语言虽然自身就有net/http包,但是说实话用起来没那么好用,resty包是go语言中一个非常受欢迎的http请求处理包,下面我们一起来学... 目录安装一、一个简单的get二、带查询参数三、设置请求头、body四、设置表单数据五、处理响应六、超

如何使用C#串口通讯实现数据的发送和接收

《如何使用C#串口通讯实现数据的发送和接收》本文详细介绍了如何使用C#实现基于串口通讯的数据发送和接收,通过SerialPort类,我们可以轻松实现串口通讯,并结合事件机制实现数据的传递和处理,感兴趣... 目录1. 概述2. 关键技术点2.1 SerialPort类2.2 异步接收数据2.3 数据解析2.

详解如何使用Python提取视频文件中的音频

《详解如何使用Python提取视频文件中的音频》在多媒体处理中,有时我们需要从视频文件中提取音频,本文为大家整理了几种使用Python编程语言提取视频文件中的音频的方法,大家可以根据需要进行选择... 目录引言代码部分方法扩展引言在多媒体处理中,有时我们需要从视频文件中提取音频,以便进一步处理或分析。本文

使用Dify访问mysql数据库详细代码示例

《使用Dify访问mysql数据库详细代码示例》:本文主要介绍使用Dify访问mysql数据库的相关资料,并详细讲解了如何在本地搭建数据库访问服务,使用ngrok暴露到公网,并创建知识库、数据库访... 1、在本地搭建数据库访问的服务,并使用ngrok暴露到公网。#sql_tools.pyfrom

使用mvn deploy命令上传jar包的实现

《使用mvndeploy命令上传jar包的实现》本文介绍了使用mvndeploy:deploy-file命令将本地仓库中的JAR包重新发布到Maven私服,文中通过示例代码介绍的非常详细,对大家的学... 目录一、背景二、环境三、配置nexus上传账号四、执行deploy命令上传包1. 首先需要把本地仓中要

Spring Cloud之注册中心Nacos的使用详解

《SpringCloud之注册中心Nacos的使用详解》本文介绍SpringCloudAlibaba中的Nacos组件,对比了Nacos与Eureka的区别,展示了如何在项目中引入SpringClo... 目录Naacos服务注册/服务发现引⼊Spring Cloud Alibaba依赖引入Naco编程s依

Java springBoot初步使用websocket的代码示例

《JavaspringBoot初步使用websocket的代码示例》:本文主要介绍JavaspringBoot初步使用websocket的相关资料,WebSocket是一种实现实时双向通信的协... 目录一、什么是websocket二、依赖坐标地址1.springBoot父级依赖2.springBoot依赖