-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathinserter.rb
47 lines (39 loc) · 1.32 KB
/
inserter.rb
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
data = [[-10, -1], [0, 2], [4, 10]]
interval = [-5, 1]
class Inserter
attr_accessor :data
def initialize(data)
@data = data
end
def execute(interval)
insert(interval)
merge
end
def insert(interval)
index = data.each_with_index do |data_int, i|
if interval.first <= data_int.first
break i
end
i + 1 if i == data.length
end
data.insert(index, interval)
end
def merge
new_data = [data.shift]
index = 0
data.each_with_index do |data_int, i|
if data_int.first <= new_data[index].first && data_int.last >= new_data[index].last
new_data[index] = data_int
elsif data_int.first <= new_data[index].first && data_int.last < new_data[index].last
new_data[index] = [data_int.first, new_data[index].last]
elsif data_int.first > new_data[index].first && data_int.last >= new_data[index].last && data_int.first < new_data[index].last
new_data[index] = [new_data[index].first, data_int.last]
else
new_data = new_data + [data_int]
index = index + 1
end
end
new_data
end
end
puts "Result = #{Inserter.new(data).execute(interval)}"