lua实现快排,选择排序--与c++一样

function sortTable(table_array,lift_id,right_id)--lua实现快速排序


if(lift_id < right_id) then
local int_X    = table_array[lift_id]--标记中间点
local   length = right_id--记录长度
local start_id = lift_id
while lift_id < right_id do
while lift_id < right_id and table_array[right_id] >= int_X do
right_id = right_id - 1
end
if lift_id < right_id then
table_array[lift_id] = table_array[right_id]
lift_id = lift_id + 1 
end--右边--

while lift_id < right_id and table_array[lift_id] < int_X do
lift_id = lift_id + 1
end
if lift_id < right_id then
table_array[right_id] = table_array[lift_id]
right_id = right_id - 1
end



end
table_array[lift_id] = int_X
--[[for i,v in ipairs(table_array) do
print(i,v)
end--]]


print("my sortTable First",start_id,lift_id-1)
sortTable(table_array,start_id,lift_id-1)
print("my sortTable Second",right_id+1,length)
sortTable(table_array,right_id+1,length)
end
end


function sortTable1(table_array)--选择排序
for i=1,#table_array-1,1 do
for j=i+1,#table_array,1 do
if table_array[i] > table_array[j] then
table_array[i],table_array[j] = table_array[j],table_array[i]
end
end
end
end


local array = {31,345,22,15454,12,5452,11,23,1254,234,12,11,65,78,22,31,44,23,41,545,31,45,234}
sortTable(array,1,23)--快速排序
--sortTable1(array)
for i,v in ipairs(array) do
print(i,v)
end
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值