ua中对table的排序一般是用lua自带的table.sort()函数排序,一般不采用自己写的排序的方式,以下来说一说

table.sort()排序和在工作中遇到的问题

1.排序的方式

table.sort(tbl,function(a,b)return a > b
end)

以上是一个简单的例子,得到的效果是对于待排序的数据的一个升序,你这样认为就是错了,例如a和b是一个样

的,返回的是false,是一个不严格的升序,严格的说可以是一个非降序排列。 
对于lua中的排序,最好是用lua自带的函数,不要自己造轮子,自己写一个排序的函数

在排序的时候应该是严格弱序,用小于关系。

正确的排序应该满足的条件,才能得到结果 
1)反自反性

cmp(a, a) === false

就是在写的排序的实现中,自己和自己比较,要永远是false 
2)非对称性

 cmp(a, b) == true ==> cmp(b, a) == false

就是a和b比较得到的是true,那么b和a比较得到的就是false,否则就不成立

3)传递性

cmp(a, b) == true && cmp(b, c) == true ==> cmp(a, c) == true

不可比的传递性

就是说a和b之间成立,b和c之间成立,那么a和c之间也要成立,才能达到传递性

如cmp(a,b) 
a == b + 1 这个就是不成立的 
如果存在这样的cmp(a, b) == true && cmp(b, c) == true,那么就假设a = 2,b = 1,c = 0 
但是cmp(a, c)就不成立了,所以这个排序是不能成功的

注:table.sort(list,function(a,b) 
end)在这里面不需要去判断a,b是否存在,他们是一定存在的,它是list中的数据,所以一定是存在的。

二:多个条件的比较 
在一些需求当中,比较的数据不是一个,是组合的形式出现的,先是比较字段a,如果相等再比较字段b,那么在

处理这样的实例当中,有以下的几种方式 
1)

function(a, b)    return a.level > b.level or a.level == b.level and a.exp > b.exp
end

2)

function(a, b)
if a.level == b.level thenreturn a.exp > b.exp
endreturn a.level > b.level
end

3)

function(a, b)if a.level ~= b.level thenreturn a.level > b.levelendreturn a.exp > b.exp
end

这三种方法当中,第三种是最好的,因为它具有很大的延展性,如果以后比较的是三个或者是三个以上的字段,那么直接在后面添加就是,第二种的话,就是要倒序的去比较,讲比较的字段分成比较的先后顺序为1,2,3,4.那么按照第二种的话,就先去判断4是否相等,然后依次是3,2是否相等。不好理解

三:排序与最值 
对于不同的排序方式,算法得到的效果不同,那么就要考虑一下算法的复杂度。 
任意table 线性查找最值 O(n) 
排序 O(nlgn) 
只需要最值且数组规模不小的时候不排序

四:多次排序 
由于在现实的例子中,可能对于要排序的条件不止一个,是两个或者是两个以上的时候,需要在一个函数中,一

次性排完。 
排序的稳定性: 
快排不具备稳定性,所以不可以按照条件顺序多次排序 
多次排序效率也不高

lua中的sort排序 反自反性 非对称性 传递性相关推荐

  1. lua中的sort排序

    lua中对table的排序一般是用lua自带的table.sort()函数排序,一般不采用自己写的排序的方式,以下来说一说 table.sort()排序和在工作中遇到的问题 1.排序的方式 table ...

  2. java中Collections.sort() 排序函数的用法

    java中Collections.sort() 排序函数的用法: 用Collections.sort方法对list排序有两种方法 第一种是list中的对象实现Comparable接口,如下: /** ...

  3. Js中的Sort排序方式

    Js中的Sort排序方式 这里只列出部分排序方式 1.Sort排序 Sort排序是数组内置函数,但他的排序是根据系统字符默认排序 //数组const arr = [3,4,2,3,123,35,65, ...

  4. 前端开发必备:js中的sort()排序函数

    碎片时间学习一下这个短短的案例技巧,将来开发中肯定会用得上的. javascript中的sort()的用法也有很多种,搜索一下就有很多了,而且都不会有什么问题.但是一下这样写法更简洁易看. <s ...

  5. python中的sort排序加换行_python中sort()排序的方法

    python中sort()排序的方法 发布时间:2020-09-01 10:57:52 来源:亿速云 阅读:110 作者:小新 这篇文章主要介绍了python中sort()排序的方法,具有一定借鉴价值 ...

  6. java中Collections.sort排序详解

    Comparator是个接口,可重写compare()及equals()这两个方法,用于比价功能:如果是null的话,就是使用元素的默认顺序,如a,b,c,d,e,f,g,就是a,b,c,d,e,f, ...

  7. sort redis php,php-redis中的sort排序函数总结

    很多人把redis当成一种数据库,其实是利用redis来构造数据库的模型,有那种数据库的味道.但是在怎么构建还是key和value的关系,与真正的关系型数据库还是不一样的. 效率高,不方便:方便的,效 ...

  8. C语言中的 Sort 排序

    Sort函数是C++中的函数,但是我们这里可以简单的使用一下:下期经行sort.qsort的本质演示: #include<stdio.h> #include<algorithm> ...

  9. Java 中使用sort排序

    刷题过程中常常遇到排序问题,Java中自带的sort方法可以非常方便的帮助我们进行排序. 常见的排序问题有两种情形: 1.对一个数组进行排序. 2.对自定义类型的类进行排序. 一,对数组进行排序: 通 ...

最新文章

  1. 太智能了!国内首批自动驾驶出租车即将在长沙上路!
  2. mysql 8重置root密码_如何在MySQL 8中重置root密码
  3. 【经典问题】maximum subset sum of vectors
  4. Inline Method(内联函数)
  5. jquery选择器之属性选择器
  6. Redis Cluster集群的搭建与实践
  7. python打印json_Python漂亮打印JSON
  8. 2008秋季-计算机软件基础-0922课堂用例(2)
  9. Axure元件库web组件库典藏版 (含五大类159小类组件 )
  10. java-房屋出租系统(项目)
  11. kafka_2.12-3.2.0安装包快速下载地址分享
  12. myeclipse 安装phpeclipse插件
  13. 【鸡汤】过往不恋,未来不迎,当下不杂
  14. stm32F4xx中文参考手册
  15. HTML .CSS实现商品详情(detail)
  16. 【调剂】长江大学张菲菲教授招收硕士生
  17. Database—DML
  18. 软件工程--团队作业2
  19. mysql转储导入错误_将MySQL转储应用于RDS时出现“无法解析表名”错误
  20. Win10插了耳机电脑还是外放怎么办

热门文章

  1. 【华为云计算产品系列】eBackup云备份原理及实战详解
  2. iOS strong和copy的区别
  3. Auto.js 悬浮 下拉框
  4. LTRIM函数和RTRIM函数
  5. C++搭建集群聊天室(十二):用户单聊及离线消息处理功能实现
  6. 【python】一篇讲透背包问题(01背包 完全背包 多重背包 二维费用背包)
  7. 求最长数字串(华为勇敢星笔试第一题)
  8. 告别流量内卷:这4个Instagram引流的方法让你亚马逊销量暴涨
  9. 四川华巨同诚:拼多多月卡购买之后怎么退款
  10. Kafka的灵魂伴侣Logi-KafkaManger(5)之运维管控–平台管理(用户管理和平台配置)