Loading [MathJax]/jax/output/CommonHTML/config.js
前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
社区首页 >专栏 >swift的闭包结构

swift的闭包结构

作者头像
用户2554571
发布于 2018-07-19 02:46:11
发布于 2018-07-19 02:46:11
57200
代码可运行
举报
文章被收录于专栏:liukaili_666888999liukaili_666888999
运行总次数:0
代码可运行

函数的设计思路是将有一定功能的代码块包装在一起,通过函数名实现复用。闭包和函数有着类似的作用,然而闭包的设计大多数情况下并不是为了代码的复用,而是传递功能代码块和处理回调结构。

如下代码所示,使用了冒泡排序算法来进行排序操作。

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
        func mySort(array:inout Array<Any>,sortClosure:(Int,Int)->Bool)->Array<Any>
        {
            for indexI in array.indices {
                if indexI == array.count - 1{
                    break
                }
                for indexJ in 0...(array.count - 1 - indexI - 1) {
                    if sortClosure(indexJ,indexJ + 1){

                    }
                    else{
                        swap(&array[indexJ], &array[indexJ + 1])
                    }
                }
            }
            return array
        }



        var array:Array<Any> = [1,2,3,4,5,6,7,8,9]
        let finalArr = mySort(array: &array,sortClosure: { (index:Int, nextIndex:Int) -> Bool in
            return (array[index] as! Int) > (array[nextIndex] as! Int)
        })

        print(finalArr)
本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2017年09月18日,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
暂无评论
推荐阅读
编辑精选文章
换一批
Swift 冒泡排序及优化
时间复杂度 冒泡排序的最佳时间复杂度为O(n),即初始状态就是排好序的。 冒泡排序的最坏时间复杂复杂度为O(n2),即初始状态就是逆序的。 冒泡排序的平均时间复杂复杂度为O(n2)
韦弦zhy
2018/09/11
1.2K0
Swift 冒泡排序及优化
Swift3.0 - Array
解释: T 为泛型 transform: 闭包函数 我们需要给它传入一个有参数有返回值的闭包函数 [T] 函数会返回给我们一个T类型的数组
酷走天涯
2018/09/14
4180
数据结构与算法 —— 归并排序
  这个题的解题思路其实就是归并排序的merge的过程。首先让我们先解这道题,便于后面更好的理解归并排序的思想。
Wu_Candy
2022/07/04
2850
数据结构与算法 —— 归并排序
快速排序OC、Swift版源码
前言: 你要问我学学算法在工作当中有什么用,说实话,当达不到那个地步的时候,可能我们不能直接的感觉到它的用处!你就抱着这样一个心态,当一些APP中涉及到算法的时候我不想给其他人画界面!公司的项目也是暂时的告一段落,程序猿一年得有一年的目标,今年的学习目标也在实施,等到今年年底的时候,希望你能觉得充实和成长吧。也打算把算法这一块的东西写成一个专题总结起来,方便以后学习。     今天总结的是快速排序,以后自己写的全都会写OC和Swift两个版本,先说说什么是快速排序。 快速排序: 百度百科这样说的:快
Mr.RisingSun
2018/01/12
7040
快速排序OC、Swift版源码
经典排序算法解析 原
    许多高级语言中都提供有排序函数,但是掌握一些经典排序算法的基本原理和编码方法还是很有必要,这个学习过程可以帮助我们更好的理解每种排序算法的设计思路,本篇博客将介绍9种十分经典的排序算法,提供了解释性语言JavaScript与编译型语言C的源代码。
珲少
2018/08/15
7430
经典排序算法解析
                                                                            原
46 道 Swift 常见面试题解
3、Set 独有的方法有哪些? 4、实现一个 min 函数,返回两个元素较小的元素 5、map、filter、reduce 的作用 6、map 与 flatmap 的区别 7、什么是 copy on write 8、如何获取当前代码的函数名和行号 9、如何声明一个只能被类 conform 的 protocol 10、guard 使用场景 11、defer 使用场景 12、String 与 NSString 的关系与区别 13、怎么获取一个 String 的长度 14、如何截取 String 的某段字符串 15、throws 和 rethrows 的用法与作用 16、try?和 try!是什么意思 17、associatedtype 的作用 18、什么时候使用 final 19、public 和 open 的区别 20、声明一个只有一个参数没有返回值闭包的别名
Swift社区
2021/11/26
5.4K0
Swift之闭包
Swift 是一门由Apple 公司开发的用于iOS和OSX设备上的开发语言,吸收了很多现代开发语言的优势。 今天看了官方的关于闭包部分的文档,感觉很不错,记录一下。
EltonZheng
2021/01/26
1.7K0
Swift讲解专题八——闭包 原
        Swift中的闭包是有一定功能的代码块,这十分类似于Objective-C中的block语法。Swift中的闭包语法风格十分简洁,其作用和函数的作用相似。
珲少
2018/08/15
3960
Swift3.0 - 函数和闭包
需求: 创建一个接口,输入true 返回 两个数相加的函数,输入false 返回两个数相减的函数
酷走天涯
2018/09/14
1.2K0
Swift3.0 - 函数和闭包
重生之“我打数据结构,真的假的?”--6.排序
排序:所谓排序,就是使⼀串记录,按照其中的某个或某些关键字的⼤⼩,递增或递减的排列起来的 操作。
hope kc
2024/09/23
1060
重生之“我打数据结构,真的假的?”--6.排序
Swift系列八 - 闭包
要想使用exec函数,则必须传入两个Int类型的参数和一个返回Int类型的函数,然后exec内部执行了传入的函数。
呆呆
2021/05/27
4370
简谈常用算法
写在前面 算法,对于iOS开发者来说,既熟悉又陌生。首先,在iOS开发过程中,对算法要求不高,用到算法时候也是少之甚少,除非是一些接近底层开发需要用到一些算法。但是,算法作为基础,又是开发者的必备技能,尤其是求职面试中一项重要考察指标。 遂,笔者在此整理一下常用的算法,以供后用。 算法中的概念 排序算法稳定性:假定在待排序的记录序列中,存在多个具有相同的关键字的记录,若经过排序,这些记录的相对次序保持不变,即在原序列中,ri=rj,且ri在rj之前,而在排序后的序列中,ri仍在rj之前,则称这种排序算法是
Jacklin999
2018/09/12
5310
Swift进阶八——泛型
当你扩展一个泛型类型的时候,不需要在扩展的定义中提供类型形式参数列表。原始类型定义的类型形式参数列表在扩展体里面仍然有效,并且原始类型形式参数列表名称也用于扩展类型形式参数。
拉维
2021/02/15
8230
字节跳动php面试题(五)
1) 面向对象是程序的一种设计方式,它利于提高程序的重用性,是程序结构更加清晰。 2) 主要特征:封装、继承、多态
李昂君
2021/12/24
1.3K0
字节跳动php面试题(五)
Swift中的闭包(Closures)
闭包是自包含的函数代码块,可以在代码中被传递和使用。 Swift 中的闭包与 C 和 Objective-C 中的代码块(blocks)以及其他一些编程语言中的 lambdas 函数比较相似。
EltonZheng
2021/01/22
2K0
算法:冒泡排序
1、输入规模:count 【就是 n】 2、算法基本操作:if (compare(array, j + 1, j)) 【先有比较再有交换】 3、是否只依赖输入规模:compare(array, j + 1, j) 形参是 array 数组元素、j + 1 和 j 都是属于 [0 ~ (count - i - 1)],而其中的 i 属于 [0 ~ (count - 1)],由此可知,compare 只依赖于输入规模这个条件;所以不用考虑最差、最优、平均效率; 【观察基本操作本身,以及基本操作的上层操作,如:那两个 for 循环】 4、建立表达式并求出增长次数: 从外向里看,第一个 for 循环,简化表示有,
半纸渊
2018/08/30
8110
算法:冒泡排序
常用排序算法代码兑现
主要推送关于对算法的思考以及应用的消息。坚信学会如何思考一个算法比单纯地掌握100个知识点重要100倍。本着严谨和准确的态度,目标是撰写实用和启发性的文章,欢迎您的关注。 01 — 回顾 五天过去了,8个主要排序算法的思想和原理图解都已经推送完了,在这些推送中,我们详细分析讨论了 各种排序算法的时间、空间复杂度; 算法的稳定性; 算法的优化改进 算法的应用场景 如果您想了解或者进一步熟悉下这些算法原理,请参考之前五天的推送: 冒泡排序到快速排序做的那些优化 直接选择排序到堆排序做的那些改进 直接插入排序到
double
2018/04/02
6990
java 版数据结构与算法
张哥编程
2024/12/17
740
【数据结构】关于冒泡排序,选择排序,插入排序,希尔排序,堆排序你到底了解多少???(超详解)
对于稳定性举例: 假如两个人考了一样的分数,那么先交卷的同学成绩因该排在后交卷的同学的前面,这样才符合常理逻辑。
用户11288949
2024/09/24
1250
【数据结构】关于冒泡排序,选择排序,插入排序,希尔排序,堆排序你到底了解多少???(超详解)
swift 闭包(闭包表达式、尾随闭包、逃逸闭包、自动闭包)
下面例子通过使用几次迭代展示了 sorted(by:)方法的定义和语法优化的方式。每一次迭代都用更简洁的方式描述了相同的功能
xy_ss
2023/11/22
8330
相关推荐
Swift 冒泡排序及优化
更多 >
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档
本文部分代码块支持一键运行,欢迎体验
本文部分代码块支持一键运行,欢迎体验