lua sort排序_python中列表排序的用法

lua sort排序_python中列表排序的用法”’lua中对table的排序一般是用lua自带的table.sort()函数排序,一般不采用自己写的排序的方式,以下来说一说table.sort()排序和在工作中遇到的问题1.排序的方式table.sort(tbl,function(a,b)returna>bend)以上是一个简单的例子,得到的效果是对于待排序的数据的一个升序,你这样认为就是错了,例如a

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE使用 1年只要46元 售后保障 童叟无欺

lua中对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 then
    return a.exp > b.exp
end
    return a.level > b.level
end

3)

function(a, b)
    if a.level ~= b.level then
        return a.level > b.level
    end
    return a.exp > b.exp
end

这三种方法当中,第三种是最好的,因为它具有很大的延展性,如果以后比较的是三个或者是三个以上的字段,

那么直接在后面添加就是,第二种的话,就是要倒序的去比较,讲比较的字段分成比较的先后顺序为1,2,3,4.

那么按照第二种的话,就先去判断4是否相等,然后依次是3,2是否相等。不好理解

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

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

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

五:随机排序(shuffle)
对于随机排序就是对于一些数据,将他们的顺序打乱,得到一个新的数据,以下是一个简单的例子

function i3k_shuffle(tbl)
    local n = #tbl
    for i = 1, n do
        local j = math.random(i, n)
        if j > i then
            tbl[i], tbl[j] = tbl[j], tbl[i]
        end
    end
end
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/169886.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • Qemu之Network Device全虚拟方案二:虚拟网卡的创建

    Qemu之Network Device全虚拟方案二:虚拟网卡的创建

    2022年1月28日
    41
  • 阿里矢量图标_ui矢量图

    阿里矢量图标_ui矢量图阿里iconfunt官网对于图标的调用写的不够详细,许多初用者不会用,下面具体介绍下总结的两种方法:一、在线调用方式1、首先建立新浪微博账号,用微博号登录iconfunt官网;2、所需要图标加入

    2022年8月1日
    7
  • 陶瓷电容分类_陶瓷电容电压级别分类

    陶瓷电容分类_陶瓷电容电压级别分类陶瓷电容分为贴装陶瓷电容和插装陶瓷电容两大类。贴装陶瓷电容是多层陶瓷电容,一般耐压不会超过50V,而层数可以达到4000层,插装的陶瓷电容中包括圆片陶瓷电容和独石电容。圆片陶瓷电容也称瓷片电容,是单层的,耐压从50V~6000V都较为普遍。同样容值下,瓷片电容受温度影响更小,更适合应用在微弱信号放大电路的滤波中。独石电容全称是片式多层陶瓷电容器,(网上有资料说其实就是陶瓷贴片电容的

    2022年8月22日
    5
  • jQuery数组反转「建议收藏」

    jQuery数组反转「建议收藏」代码很短,不过实现的时候需要原始数组的配合。并且,对数字索引数组支持还不错,索引不连续的一样支持(对于非连续索引,只取最大的索引加1作为数组的长度,不影响数组元素反转)。 $(function(){ vararr1=[23,45,77,2,5]; //数组反转。 varlen1=arr1.length; varnewarr1=$.map(

    2022年5月15日
    43
  • jvm内存模型、jvm内存结构、Java内存结构、Java内存模型(JMM)、Java对象模型的区别(吐血研究整理)

    jvm内存模型、jvm内存结构、Java内存结构、Java内存模型(JMM)、Java对象模型的区别(吐血研究整理)jvm内存模型:JVM内存模型则是指JVM的内存分区。jvm内存结构:等同于Java内存结构,汉语虽然博大精深,但是也经常会因为命名很雷同让人懵逼或者混淆不清。Java内存结构:Java内存模型(JMM):java内存模型又称为JMM。为了解决Java多线程对共享数据的读写一致性问题,通过Happens-Before语义(延伸出了as-if-serial)定义了Java程序对数据的访问规则,修正之前由于读写冲突导致的Cache数据不一致的问题。具体到HotspotVM的实现..

    2022年5月10日
    37
  • 多线程notify notifyall_线程wait和notify使用

    多线程notify notifyall_线程wait和notify使用涉及JAVA线程的状态问题,不清楚的可以参考我的另一篇:https://blog.csdn.net/q5706503/article/details/84350887我们知道notify是Object的本地final方法,无法被重写,用来唤醒线程,那么该怎么用,唤醒的又是谁呢?用一句话做答复:notify唤醒的是其所在锁所阻塞的线程不理解看下面的分析和例子:wait…

    2025年10月4日
    1

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号