Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

Lua : remove duplicate elements

Tags:

lua

lua-table

i am having a table in lua

test = {1,2,4,2,3,4,2,3,4,"A", "B", "A"}

I want to remove all duplicate elements in table.
Output should be

test = {1,2,4,3,"A","B"}

EDIT:

My try :

> items = {1,2,4,2,3,4,2,3,4,"A", "B", "A"}
> flags = {}
> for i=1,table.getn(items)  do
if not flags[items[i]] then
      io.write(' ' .. items[i])
      flags[items[i]] = true
   end
>> end
 1 2 4 3 A B>

It is working fine now. Thanks for answers and comments.

like image 369
Prashant Gaur Avatar asked Nov 19 '13 08:11

Prashant Gaur


3 Answers

Similar to example given by @Dimitry but only one loop

local test = {1,2,4,2,3,4,2,3,4,"A", "B", "A"}
local hash = {}
local res = {}

for _,v in ipairs(test) do
   if (not hash[v]) then
       res[#res+1] = v -- you could print here instead of saving to result table if you wanted
       hash[v] = true
   end

end
like image 110
vogomatix Avatar answered Feb 05 '23 20:02

vogomatix


local test = {1,2,4,2,3,4,2,3,4,"A", "B", "A"}

-- make unique keys
local hash = {}
for _,v in ipairs(test) do
    hash[v] = true
end

-- transform keys back into values
local res = {}
for k,_ in pairs(hash) do
    res[#res+1] = k
end

-- 1 2 3 4 A B
for _,v in ipairs(res) do
    print(v)
end

test = res

... a simple, straightforward solution just from the head, but I think, the hint is given in the PiL book

what have you tried to solve the problem?

like image 33
Dmitry Ledentsov Avatar answered Feb 05 '23 21:02

Dmitry Ledentsov


local xx = {'a','b','c','d','a','d','f','g','a'}
table.sort(xx)
local result = {}

for key,value in ipairs(xx) do
  if value ~=xx[key+1] then
    table.insert(result,value)
  end
end

for key,value in ipairs(result) do
  print(key,value)   
end
like image 34
Ilhami Mounir Aziz Girgis Avatar answered Feb 05 '23 19:02

Ilhami Mounir Aziz Girgis