主页 > 知识库 > Lua中写排序算法实例(选择排序算法)

Lua中写排序算法实例(选择排序算法)

热门标签:怎么去除地图标注 清朝地图标注哈尔滨 冀州市地图标注 地图标注大厦 百度地图标注早餐区域 新岸线智能电销机器人 武汉外呼防封系统多少钱 个人怎么在地图标注需要的店铺 漳州智云呼电话机器人

早在12年的时候,学过一个月的lua,当时看的是《programming in lua》,一直没用过,然后就忘了。现在我下定决心重新学习它。

时间久了,对编程的热情也随之消失殆尽,很难找回当初编程的乐趣了。近来一放假就玩英雄联盟,太浪费时间,玩个十来局一天就过去了,浑浑噩噩的,这实在不是我想过的。所以,今天我把它卸载了。如果你也是英雄联盟玩家,希望你不要沉迷其中。

从事游戏开发还不到一年,已经有点厌倦了,同事们一致认为游戏公司普遍很浮躁,有些小公司没有一点技术氛围。我知道的有些程序员,技术远远比普通游戏程序员强,由于靠谱的游戏公司太少而做其他开发了。

吐槽完了,用lua 写个选择排序:

复制代码 代码如下:

--select sort
function select_sort(t)
     for i=1, #t - 1 do
          local min = i
          for j=i+1, #t do
               if t[j] t[min]  then
                    min = j
               end
          end
          if min ~= i then
               t[min], t[i] = t[i], t[min]
          end
     end
end
tb = {77, 99, 2, 334, 22, 32, 9}
print("-------------before--------------")
print(table.concat(tb, " "))
print("-------------after---------------")
select_sort(tb)
print(table.concat(tb, " "))

table带有个sort函数,手册说明如下:
复制代码 代码如下:

Sorts table elements in a given order, in-place, from table[1] to table[n], where n is the length of the table. If comp is given, then it must be a function that receives two table elements, and returns true when the first is less than the second (so that not comp(a[i+1],a[i]) will be true after the sort). If comp is not given, then the standard Lua operator is used instead.
The sort algorithm is not stable; that is, elements considered equal by the given order may have their relative positions changed by the sort.

因此你也可以这么写:
复制代码 代码如下:

function comp(a, b)
     return a b
end

table.sort(tb, comp)


当然,通常你可以使用匿名的函数
复制代码 代码如下:

table.sort(tb, function(a, b)
     return a b
end)

标签:台湾 天门 金昌 儋州 潍坊 德宏 宣城 天门

巨人网络通讯声明:本文标题《Lua中写排序算法实例(选择排序算法)》,本文关键词  Lua,中写,排序,算法,实例,;如发现本文内容存在版权问题,烦请提供相关信息告之我们,我们将及时沟通与处理。本站内容系统采集于网络,涉及言论、版权与本站无关。
  • 相关文章
  • 下面列出与本文章《Lua中写排序算法实例(选择排序算法)》相关的同类信息!
  • 本页收集关于Lua中写排序算法实例(选择排序算法)的相关信息资讯供网民参考!
  • 推荐文章