Kotlin 丰富的函数特性
Kotlin 是一门基于 JVM 的现代编程语言,它提供了丰富的函数特性,使得编写简洁、灵活且可读性强的代码成为可能。以下是 Kotlin 函数的一些主要特性:
一、函数声明与调用
在 Kotlin 中,使用 fun
关键字来声明函数。函数声明的基本结构如下:
fun functionName(parameters: ParameterType): ReturnType {// 函数体// 可以是表达式或代码块return returnValue // 如果是表达式函数体
}
functionName
是你为函数取的名字。parameters
是函数的参数列表,每个参数都需要指定参数名和参数类型。ReturnType
是函数的返回类型。- 函数体可以是单个表达式或者是一个代码块,用来定义函数的操作。
- 如果函数体是表达式,可以直接返回结果值,不需要使用
return
关键字。 - 如果函数体是代码块,可以使用
return
关键字来返回结果。
调用函数就是在代码中使用函数来执行其中定义的操作。Kotlin 函数的调用与其他编程语言相似,但也有一些特点:
val result = functionName(argument1, argument2)
result
是存储函数调用结果的变量。functionName
是要调用的函数的名称。argument1
,argument2
等是函数需要的参数,按照函数声明的参数顺序提供。
二、参数默认值(Default Arguments)
Kotlin 中的函数可以为参数设置默认值,这意味着在调用函数时可以选择性地省略这些参数。参数默认值通过在函数定义中使用等号(=
)来指定。
fun greet(name: String, message: String = "Hello") {println("$message, $name!")
}// 调用函数时省略第二个参数
greet("John") // 输出:Hello, John!// 传递自定义的第二个参数
greet("Mary", "Hi") // 输出:Hi, Mary!
在上面的示例中,greet
函数有两个参数:name
和 message
。其中 message
参数有一个默认值 "Hello"
。在第一个函数调用中,我们省略了 message
参数,因此它将使用默认值 "Hello"
。而在第二个函数调用中,我们传递了自定义的 message
值 "Hi"
。
通过使用参数默认值,我们可以在函数定义时为参数提供合理的默认值,从而简化函数的调用,使代码更具可读性和灵活性。
三、命名参数(Named Arguments)
命名参数(Named Arguments)是 Kotlin 中的一个特性,允许在函数调用时使用参数的名称来指定参数的值,而不必按照参数定义的顺序传递参数。
使用命名参数可以提高代码的可读性和可维护性,尤其是在函数有多个参数且具有相同类型的情况下。
fun printUser(name: String, age: Int) {println("Name: $name, Age: $age")
}// 使用命名参数来调用函数
printUser(name = "John", age = 30)
printUser(age = 25, name = "Mary")
在上面的示例中,我们定义了一个函数 printUser
,接受两个参数 name
和 age
。在函数调用时,我们使用参数的名称来指定参数的值。这样做可以明确地指定每个参数的含义,而不依赖于参数的位置。
使用命名参数可以避免参数位置的混淆,特别是当函数有多个具有相同类型的参数时。它还使得代码更易读、更易于理解,并且可以更方便地修改参数的值而不必改变参数的顺序。
四、可变参数(Varargs)
可变参数(Varargs)是 Kotlin 中的一种特性,它允许函数接受可变数量的参数,即参数个数可以是可变的,而不需要在函数定义时明确指定参数个数。
在 Kotlin 中,使用 vararg
关键字来标识可变参数。可变参数在函数内部被视为一个数组,并且可以使用类似于数组的方式进行操作。
fun sum(vararg numbers: Int): Int {var result = 0for (number in numbers) {result += number}return result
}val total = sum(1, 2, 3, 4, 5) // 返回:15
在上面的示例中,我们定义了一个 sum
函数,它接受一个可变参数 numbers
,类型为 Int
。在函数内部,我们将可变参数 numbers
视为一个整数数组,并通过遍历数组的方式计算它们的总和。
使用可变参数可以方便地传递不定数量的参数给函数,而不必手动创建数组或指定参数个数。可以通过直接在函数调用时传递参数列表,也可以将一个已有的整数数组传递给可变参数。
需要注意的是,可变参数只能作为函数的最后一个参数,且每个函数最多只能有一个可变参数。
五、表达式体函数(Expression Body Function)
表达式体函数(Expression Body Functions)是 Kotlin 中的一种简化函数定义的语法。它允许在函数定义中使用等号(=
)和单个表达式来代替函数体的大括号({}
)。
表达式体函数适用于那些函数体只包含单个表达式的情况,这样可以减少冗余的代码,使函数定义更加简洁。
fun add(a: Int, b: Int): Int = a + b
在上面的示例中,函数 add
接受两个参数 a
和 b
,并返回它们的和。由于函数体只有一条语句,我们可以使用等号将表达式直接作为函数的返回值。
这种简化的写法可以提高代码的简洁性和可读性,尤其是对于简单的函数。需要注意的是,这种简化的写法只适用于单个表达式的函数体,如果函数体包含多个语句或需要进行复杂的逻辑处理,仍然需要使用大括号({}
)来定义函数体。
六、函数嵌套
函数嵌套是指在一个函数内部定义并使用另一个函数。在 Kotlin 中,我们可以在一个函数内部定义其他函数,这些被嵌套的函数可以直接访问外部函数的局部变量和参数。
函数嵌套可以提高代码的可读性和可维护性,尤其是当一个函数内部需要进行复杂的逻辑或算法时。通过将逻辑划分为多个嵌套的函数,可以更好地组织代码,并将复杂的问题分解为更小的部分。
以下是一个示例,演示了函数嵌套的用法:
fun calculateFactorial(n: Int): Long {fun factorial(num: Int): Long {return if (num == 0) 1 else num * factorial(num - 1)}return factorial(n)
}val result = calculateFactorial(5) // 返回:120
在上面的示例中,我们定义了一个外部函数 calculateFactorial
,它接受一个整数 n
,并计算其阶乘。在函数内部,我们定义了一个嵌套函数 factorial
,用于递归地计算阶乘。嵌套函数可以访问外部函数的参数 n
,并使用它进行计算。
需要注意的是,嵌套函数只在外部函数内部可见,无法从外部函数之外的代码中直接访问。这种限制有助于保持函数的封装性和代码的清晰性。
通过使用函数嵌套,我们可以将复杂的逻辑划分为更小的部分,提高代码的可读性和可维护性。同时,函数嵌套还可以避免命名冲突,因为嵌套函数的作用域仅限于其外部函数。
七、扩展函数(Extension Functions)
扩展函数(Extension Functions)是 Kotlin 中的一种特性,它允许我们向现有的类添加新的函数,而无需修改原始类的定义。
1、 Kotlin 中扩展函数如何定义
通过扩展函数,我们可以在不修改类的源代码的情况下,为类添加新的行为和功能。扩展函数的语法很简洁,只需要在函数名前面加上被扩展的类的类型,并使用 .
进行连接。
// StringExtensions.kt
fun String.isPalindrome(): Boolean {val reversed = this.reversed()return this == reversed
}val palindrome = "madam".isPalindrome() // 返回:true
val notPalindrome = "hello".isPalindrome() // 返回:false
在上面的示例中,我们为 String
类添加了一个扩展函数 isPalindrome
。这个函数用于判断一个字符串是否是回文(正读和反读都相同)。在函数体内部,我们通过调用原始字符串的 reversed()
函数来获得反向字符串,并将其与原始字符串进行比较。
需要注意的是,扩展函数实际上并没有修改原始类的定义,它只是对现有类的实例提供了一个额外的函数。扩展函数可以对任何类进行定义,包括标准库类、第三方库类,甚至是我们自己定义的类。
通过使用扩展函数,我们可以在不修改类的源代码的情况下,为类添加新的函数,提供更好的代码组织和可读性。但需要注意的是,扩展函数无法访问类的私有成员,它只能访问公有成员。
2、在 Java 代码中使用该扩展函数
在 Java 代码中使用该扩展函数时,需要通过导入扩展函数所在的 Kotlin 文件的全限定名,并在调用时将原始对象作为第一个参数传递给扩展函数:
// JavaClass.java
import com.example.extensions.StringExtensionsKt;public class JavaClass {public static void main(String[] args) {String str = "madam";boolean isPalindrome = StringExtensionsKt.isPalindrome(str);System.out.println(isPalindrome);}
}
在上述示例中,我们在 Kotlin 文件中定义了一个名为 isPalindrome()
的扩展函数。在 Java 代码中,我们通过导入扩展函数所在的 Kotlin 文件的全限定名,即 com.example.extensions.StringExtensionsKt
,并将原始字符串 str
作为第一个参数传递给扩展函数。
需要注意的是,Kotlin 的扩展函数在 Java 中实际上是被转换为静态方法,并以 StringExtensionsKt
类名作为前缀,因此在 Java 中调用扩展函数时需要使用这个特殊的类名前缀。
3、扩展函数的静态解析
在 Kotlin 中,扩展函数的调用是静态解析的,这意味着调用哪个扩展函数是在编译时确定的,而不是在运行时动态决定的。以下是一些关于扩展函数静态解析的特点:
- 静态解析的目标是根据函数调用的接收者类型来确定使用哪个扩展函数。接收者类型是指在调用扩展函数时使用的对象类型。
- 如果存在多个可用的扩展函数与接收者类型匹配,编译器将选择具有最具体匹配类型的扩展函数。
- 静态解析遵循编译时类型,而不是运行时类型。这意味着如果调用扩展函数的对象类型是接收者类型的子类型,那么仍然会选择接收者类型的扩展函数。
- 扩展函数的调用不会影响对象的虚拟调度。即使对象的实际类型具有与扩展函数相同的函数签名,也不会调用扩展函数。
下面是一个示例来说明扩展函数的静态解析:
open class Animal
class Cat : Animal()fun Animal.sayHello() {println("Hello, Animal!")
}fun Cat.sayHello() {println("Hello, Cat!")
}fun greet(animal: Animal) {animal.sayHello()
}fun main() {val animal: Animal = Cat()greet(animal)
}
在上面的示例中,我们定义了两个扩展函数 sayHello()
,分别适用于 Animal
类和 Cat
类。然后,在 greet()
函数中,我们通过参数接收一个 Animal
对象,并调用 sayHello()
扩展函数。
由于静态解析的原则,尽管 animal
的实际类型是 Cat
,但编译器仍然会选择调用 Animal
类型的扩展函数。因此,程序输出将是 “Hello, Animal!”。
总结来说,Kotlin 的扩展函数是静态解析的,根据编译时类型来确定使用哪个扩展函数。这种静态解析机制使得扩展函数的调用在编译时就能确定,并且不会受到对象的实际类型的影响。
这些只是 Kotlin 函数的一部分特性,它还有很多其他特性,如Lamdba闭包、高级函数、内联函数等。这些特性使得 Kotlin 在编写函数式编程风格的代码时非常强大和灵活。
相关文章:
![](https://www.ngui.cc/images/no-images.jpg)
Kotlin 丰富的函数特性
Kotlin 是一门基于 JVM 的现代编程语言,它提供了丰富的函数特性,使得编写简洁、灵活且可读性强的代码成为可能。以下是 Kotlin 函数的一些主要特性: 一、函数声明与调用 在 Kotlin 中,使用 fun 关键字来声明函数。函数声明的基本…...
![](https://www.ngui.cc/images/no-images.jpg)
Node.js怎么搭建HTTP服务器
在 Node.js 中搭建一个简单的 HTTP 服务器非常容易。以下是一个基本的示例,演示如何使用 Node.js 创建一个简单的 HTTP 服务器: // 导入 http 模块 const http require(http); // 创建一个 HTTP 服务器 const server http.createServer((req, res) …...
![](https://www.ngui.cc/images/no-images.jpg)
基于Redisson的联锁(MultiLock)
基于Redis的分布式MultiLock对象允许对Lock对象进行分组并将它们作为单个锁进行处理。每个RLock对象可能属于不同的Redisson实例。 如果获取的Redisson实例MultiLock崩溃,那么它可能永远挂在获取状态。为了避免这种情况,Redisson维护了一个锁看门狗&…...
![](https://img-blog.csdnimg.cn/149dc08daa844b0b98937aa15a61de67.png)
人脸识别平台批量导入绑定设备的一种方法
因为原先平台绑定设备是通过一个界面进行人工选择绑定或一个人一个人绑定设备。如下: 但有时候需要在几千个里选择出几百个,那这种方式就不大现实了,需要另外一种方法。 目前相到可以通过导入批量数据进行绑定的方式。 一、前端 主要是显示…...
![](https://img-blog.csdnimg.cn/ac09e6974e7e4a4aa28752d2573f28a0.png)
MySQL—MySQL的NULL值是怎么存放的
一、引言 1、MySQL数据存放在哪个文件? 创建一个数据库会产生三种格式的文件,分别是.opt格式、.frm格式、.ibd格式。 opt格式:用来存储当前数据库的默认字符集和字符校验规则。 frm格式:该文件是用来保存每个表的元数据信息的&…...
![](https://img-blog.csdnimg.cn/f6e040c599d849af8112a986a6afd216.png)
sql server删除历史数据
1 函数 datediff函数: DATEDIFF ( datepart , startdate , enddate )datepart的取值可以是year,quarter,Month,dayofyear,Day,Week,Hour,minute,second,millisecond startdate 是从 enddate 减去。如果 startdate 比 enddate 晚,返回负值。 2 例子 删除2023年以…...
![](https://www.ngui.cc/images/no-images.jpg)
目标检测项目中,使用python+xml.etree.ElementTree修改xml格式标注文件中的类别名称
需求: 数据集的数据增强中,有时需要将xml标注文件中的类别做修改为新类别,或者将几个类别合并为一个类别。 解决方法: 使用pythonimport xml.etree.ElementTree将xml标注文件中的类别名称做修改。代码如下&…...
![](https://img-blog.csdnimg.cn/cb2ef3652c594fb7b724d151dc355d67.png)
最新域名和子域名信息收集技术
域名信息收集 1.WHOIS查询 WHOIS是一个标准的互联网协议,可用于收集网络注册信息、注册域名﹑IP地址等信息。简单来说,WHOIS就是一个用于查询域名是否已被注册及注册域名详细信息的数据库(如域名所有人、域名注册商)…...
![](https://img-blog.csdnimg.cn/9c29e8aebd154dccb391d023ce280532.png)
C语言基础之——指针(上)
前言:小伙伴们又见面啦!本期内容,博主将展开讲解有关C语言中指针的上半部分基础知识,一起学习起来叭!!! 目录 一.什么是指针 二.指针类型 1.指针的解引用 2.指针-整数 三.野指针 1.野指针…...
![](https://img-blog.csdnimg.cn/img_convert/c4d21c587c870732260e8bc02cdce8b9.png)
构建 NodeJS 影院预订微服务并使用 docker 部署(04/4)
一、说明 构建一个微服务的电影网站,需要Docker、NodeJS、MongoDB,这样的案例您见过吗?如果对此有兴趣,您就继续往下看吧。 我们前几章的快速回顾 第一篇文章介绍了微服务架构模式,并讨论了使用微服务的优缺点。第二篇…...
![](https://img-blog.csdnimg.cn/918037207908423dbfa235c2ec019420.png)
SpringBootWeb案例 Part3
目录 1. 新增员工 1.1 需求 1.2 接口文档 1.3 思路分析 PostMapping RequestBody //把前端传递的JSON数据填充到实体类中 1.4 功能开发 1.5 功能测试 1.6 前后端联调 2. 文件上传 2.1 文件上传简介 Spring中提供了一个API:MultipartFile,使…...
![](https://www.ngui.cc/images/no-images.jpg)
C++中using 用法
C中的 using 关键字用于引入命名空间、类型别名和模板别名。以下是 using 关键字的几种常见用法及其中文解析: 1. 引入命名空间: using namespace std; 中文解析:引入 std 命名空间,使得命名空间中的成员在当前作用域内可直接使…...
![](https://img-blog.csdnimg.cn/5b334bcfbab547c6a7916e943ac7c3c0.png)
window下jdk安装及更换jdk版本的一些问题。
目录 jdk安装jdk的选择。oracle的jdk怎么安装。openjdk怎么安装。 jdk的版本控制。更换jdk的一些问题。 jdk安装 jdk的选择。 目前有两种可选的jdk,oracle的和开源的Openjdk,这两种jdk的区别可以自行查阅,就结果而言,openjdk开源…...
![](https://img-blog.csdnimg.cn/img_convert/33719383053bc55fb62121d03e8ff776.png)
GPT4模型架构的泄漏与分析
迄今为止,GPT4 模型是突破性的模型,可以免费或通过其商业门户(供公开测试版使用)向公众提供。它为许多企业家激发了新的项目想法和用例,但对参数数量和模型的保密却扼杀了所有押注于第一个 1 万亿参数模型到 100 万亿参…...
GEE/PIE遥感大数据处理与典型案例丨数据整合Reduce、云端数据可视化、数据导入导出及资产管理、机器学习算法等
目录 专题一:初识GEE和PIE遥感云平台 专题二:GEE和PIE影像大数据处理基础 专题三:数据整合Reduce 专题四:云端数据可视化 专题五:数据导入导出及资产管理 专题六:机器学习算法 专题七:…...
![](https://img-blog.csdnimg.cn/257f520fff9e41c9b459b9578a882104.png)
STM32--DMA
文章目录 DMA简介DMA特性 DMA框图DMA基本结构DMA请求数据宽度对齐DMA数据转运工程DMAADC多通道 DMA简介 直接存储器存取(DMA)用来提供在外设和存储器之间或者存储器和存储器之间的高速数据传输。无须CPU干预,数据可以通过DMA快速地移动,这就节省了CPU的…...
![](https://www.ngui.cc/images/no-images.jpg)
mongodb和redis的用途
MongoDB和Redis都是常见的NoSQL数据库,它们有不同的特点和用途。 MongoDB的主要特点和用途: 数据存储:MongoDB是一种面向文档的数据库,以JSON样式的BSON文档(二进制JSON)的形式存储数据。它支持复杂的数据…...
![](https://img-blog.csdnimg.cn/img_convert/26e4f78135ffd34eed17e7c5be537dcc.png)
【动手学深度学习】--18.图像增广
文章目录 图像增广1.常用的图像增广方法1.1翻转和裁剪1.2改变颜色1.3结合多种图像增广方法 2.使用图像增广进行训练3.训练 图像增广 官方笔记:图像增广 学习视频:数据增广【动手学深度学习v2】 图像增广在对训练图像进行一系列的随机变化之后ÿ…...
![](https://img-blog.csdnimg.cn/633b82685eee48b5811d2a9243d6a73b.png)
数据分析--统计学知识
描述型统计 描述统计 1.集中趋势 :众数、平均数、分位数 2.离散趋势: 极值(max)、极差(max-min)、平均差、方差、标准差、分位差 3.分布:峰泰、偏度 推理型统计 概率分布:离散型…...
![](https://img-blog.csdnimg.cn/b92d40571f164afd89ce38f4d556068e.png#pic_center)
matlab 计算点云协方差矩阵
目录 一、概述1、算法概述2、主要函数二、代码示例三、结果展示四、参数解析输入参数输出参数五、参考链接本文由CSDN点云侠原创,原文链接。如果你不是在点云侠的博客中看到该文章,那么此处便是不要脸的爬虫。 一、概述...
![](https://www.ngui.cc/images/no-images.jpg)
python进阶之图像编程 pillow扩展库
一、概述 1.1pillow简介 Python Imaging Library (PIL)是python 下的图像处理模块,支持多种格式,并提供强大的图像处理功能,可以通过pip进行安装后使用。 1.2pillow具体应用 Pillow 库是 Python3 最常用的图像处理库,它支持多种图像格式&a…...
![](https://www.ngui.cc/images/no-images.jpg)
TiCDC Canal-JSON 消息接收示例(Java 版)
1.引言 业务程序经常会通过各式各样的缓存来提升用户的访问速度。 由于存在缓存,在一些实时性要求较高的场景中,需要在数据变更的同时将数据缓存进行更新或删除。 如果数据本身由其他业务部门提供,就无法在写入的同时做缓存的一致性处理。…...
![](https://img-blog.csdnimg.cn/img_convert/046e1b5c3ed89ba8faa8b28e207a052a.png)
SQLite、MySQL、PostgreSQL3个关系数据库之间的对比
引言 关系数据模型以行和列的表格形式组织数据,在数据库管理工具中占主导地位。今天还有其他数据模型,包括NoSQL和NewSQL,但是关系数据库管理系统(RDBMS)仍然占主导地位用于存储和管理全球数据。 本文比较了三种实现最…...
![](https://img-blog.csdnimg.cn/img_convert/e1b8a62fe5fcfb378364fc38fdd58d37.jpeg)
开源容灾备份软件,开源cdp备份软件
数据的安全性和完整性面临着硬件问题、黑客攻击、人为错误等各种威胁。在这种环境下,开源容灾备份软件应运而生,通过提供自动数据备份和恢复,有效地保证了公司的数据安全。 一、开源容灾备份软件的定义和作用 开源容灾备份软件是一种基于开源…...
![](https://www.ngui.cc/images/no-images.jpg)
Java合并区间
问题: 以数组 intervals 表示若干个区间的集合,其中单个区间为 intervals[i] [starti, endi] 。请你合并所有重叠的区间,并返回 一个不重叠的区间数组,该数组需恰好覆盖输入中的所有区间 。 示例: 示例 1ÿ…...
![](https://www.ngui.cc/images/no-images.jpg)
前端面试:【代码质量与工程实践】单元测试、集成测试和持续集成
在现代软件开发中,确保代码质量是至关重要的。单元测试、集成测试和持续集成是关键的工程实践,用于提高代码的可靠性和可维护性。本文将深入探讨这些概念,以及它们如何在软件开发中发挥作用。 1. 单元测试(Unit Testing࿰…...
![](https://img-blog.csdnimg.cn/bed2a51fe27642ea9e21ebfc5006394c.png)
2023/8/17总结
项目完善: 算法推荐 item-CF 算法推荐我主要写的是协同过滤算法,然后协同过滤算法分成俩种—— 基于用户的 user-CF 基于物品的 item-CF 因为害怕用户冷启动,和数据量的原因 我选择了 item-CF 主要思路是——根据用户的点赞列表&…...
![](https://img-blog.csdnimg.cn/0577df4069494af19d2d7fe82eb71c41.png)
REDIS 7 教程 数据类型-进阶篇
⑥ *位图 bitmap 1. 理论 由0和1 状态表现的二进制位的bit 数组。 说明:用String 类型作为底层数据结构实现的一种统计二值状态的数据类型 位图本质是数组,它是基于String 数据类型的按位操作。该数组由多个二进制位组成,每个二进制位都对应一个偏…...
![](https://img-blog.csdnimg.cn/img_convert/d7b74195e18ace5710d9a7e29fc45358.png)
图文并茂:Python Tkinter从入门到高级实战全解析
目录 介绍什么是Tkinter?准备工作第一个Tkinter程序界面布局事件处理补充知识点 文本输入框复选框和单选框列表框弹出对话框 综合案例:待办事项列表总结 介绍 欢迎来到本篇文章,我们将带您深入了解如何在Python中使用Tkinter库来创建图形用…...
![](https://img-blog.csdnimg.cn/8278907884f245f595314d9363b984cd.png#pic_center)
npm和yarn的区别?
文章目录 前言npm和yarn的作用和特点npm和yarn的安装的机制npm安装机制yarn安装机制检测包解析包获取包链接包构建包 总结后言 前言 这一期给大家讲解npm和yarn的一些区别 npm和yarn的作用和特点 包管理:npm 和 yarn 可以用于安装、更新和删除 JavaScript 包。它们提…...
![](/images/no-images.jpg)
做网站政府扶持/南京seo培训
内容来源:2017年5月20日,腾讯高级软件工程师吴友强在“中生代技术沙龙系列之互联网大数据”进行《腾讯云大数据实战》演讲分享。IT 大咖说作为独家视频合作方,经主办方和讲者审阅授权发布。阅读字数:1954 | 3分钟阅读嘉宾演讲视频…...
![](/images/no-images.jpg)
网站微信推广怎么做/百度网站搜索排名
嗅探器 可以窃听网络上流经的数据包。 用集线器hub组建的网络是基于共享的原理的, 局域网内所有的计算机都接收相同的数据包, 而网卡构造了硬件的“过滤器“ 通过识别MAC地址过滤掉和自己无关的信息, 嗅探程序只需关闭这个过滤器,…...
![](/images/no-images.jpg)
人大代表网站建设/google下载安装
正则化技术 一种防止过拟合,提高泛化能力的技巧,因此算法正则化的研究成为机器学习中主要的研究主题。此外,正则化还是训练参数数量大于训练数据集的深度学习模型的关键步骤。 正则化可以避免算法过拟合,过拟合通常发生在算法…...
![](/images/no-images.jpg)
帮人家做网站/全国教育培训机构平台
http://www.geeksforgeeks.org/k-largestor-smallest-elements-in-an-array/ 可以用冒泡排序。外循环k次,不用n次。O(nk)。 我想用quick sort的partition。每一次选择一个pivot,然后确定它的index。如果它的位置大于k,那么就在[left, index-1…...
![](/images/no-images.jpg)
淄博微网站/重庆seo霸屏
这是一份 JavaScript 冒泡排序的代码: functionbubbleSort(arr) {for (var i 0; i < arr.length - 1; i) {for (var j 0; j < arr.length - i - 1; j) {if (arr[j] > arr[j 1]) {var temp arr[j];arr[j] arr[j 1];arr[j 1] temp;}}}return arr;...
![](https://img-blog.csdnimg.cn/451fd02cb4a541c3bf80b23ff6aa1829.png)
推荐黄的网站/搜索关键词排名优化软件
实验目的: l掌握BGP联邦工作原理 实验说明: l通过此实验练习,可以灵活的使用BGP联邦 实验环境: l五台支持SPSERVICES的IOS的路由器 l直通线 实验拓扑: 实验步骤: R4(config)#interface f0/0 R4(config-if)#i…...