使用Julia将项目插入到排序列表中(包含和不包含重复项)

时间:2014-09-05 03:10:35

标签: sorting insert julia

主要问题:将项目插入已使用Julia排序的列表的最快方法是什么?

目前,我这样做:

v = [1, 2, 3, 5] #example list
x = 4 #value to insert
index = searchsortedfirst(v, x) #find index at which to insert x
insert!(v, index, x) #insert x at index

奖金问题:如果我想同时确保没有重复项怎么办?

1 个答案:

答案 0 :(得分:7)

您可以使用searchsorted获取值出现的索引范围而不是第一个索引,然后使用splice!将一组新值替换为该范围内的值:< / p>

insert_and_dedup!(v::Vector, x) = (splice!(v, searchsorted(v,x), [x]); v)

这是一个很好的小单行,可以做你想要的。

julia> v = [1, 2, 3, 3, 5];

julia> insert_and_dedup!(v, 4)
6-element Array{Int64,1}:
 1
 2
 3
 3
 4
 5

julia> insert_and_dedup!(v, 3)
5-element Array{Int64,1}:
 1
 2
 3
 4
 5

这让我觉得splice!应该处理替换是单个值而不是数组的情况,所以我可以添加该功能。