Binary Search Insertion With Duplicate Elements

Left-most and right-most insertion with binary search.

Introduction

Previously, I posted an article that introduces 3 different binary search templates: https://chuzcjoe.github.io/2024/05/22/misc-how-to-write-bug-free-binary-search/

Writing binary search code can be tricky, and without careful attention, it’s easy to end up in an infinite loop. Binary search for insertion is even more challenging, particularly when deciding how to adjust the left and right pointers under certain conditions. Fortunately, with the templates I’ve provided, you only need to make slight adjustments to adapt them for insertion purposes.

We will reuse the first provided template and make adjustment based on it.

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
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
#include <iostream>
#include <vector>

int binaryInsertMostLeft(std::vector<int>& arr, int target) {
int i = 0;
int j = arr.size() - 1;
while (i <= j) {
int mid = (i + j) / 2;
if (arr[mid] >= target)
j = mid - 1;
else
i = mid + 1;
}
return i;
}

int binaryInsertMostRight(std::vector<int>& arr, int target) {
int i = 0;
int j = arr.size() - 1;
while (i <= j) {
int mid = (i + j) / 2;
if (arr[mid] > target)
j = mid - 1;
else
i = mid + 1;
}
return i;
}

int main() {
std::vector<int> nums{1, 1, 2, 5, 5, 8, 10};
std::cout << "insert to the most left position\n";
int left = binaryInsertMostLeft(nums, 0);
std::cout << "0 is inserted at index: " << left << '\n';
left = binaryInsertMostLeft(nums, 1);
std::cout << "1 is inserted at index: " << left << '\n';
left = binaryInsertMostLeft(nums, 2);
std::cout << "2 is inserted at index: " << left << '\n';
left = binaryInsertMostLeft(nums, 3);
std::cout << "3 is inserted at index: " << left << '\n';
left = binaryInsertMostLeft(nums, 9);
std::cout << "9 is inserted at index: " << left << '\n';
left = binaryInsertMostLeft(nums, 11);
std::cout << "11 is inserted at index: " << left << '\n';

std::cout << "insert to the most right position\n";
int right = binaryInsertMostRight(nums, 0);
std::cout << "0 is inserted at index: " << right << '\n';
right = binaryInsertMostRight(nums, 1);
std::cout << "1 is inserted at index: " << right << '\n';
right = binaryInsertMostRight(nums, 2);
std::cout << "2 is inserted at index: " << right << '\n';
right = binaryInsertMostRight(nums, 3);
std::cout << "3 is inserted at index: " << right << '\n';
right = binaryInsertMostRight(nums, 5);
std::cout << "5 is inserted at index: " << right << '\n';
right = binaryInsertMostRight(nums, 9);
std::cout << "9 is inserted at index: " << right << '\n';
right = binaryInsertMostRight(nums, 11);
std::cout << "11 is inserted at index: " << right << '\n';
return 0;
}
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
insert to the most left position
0 is inserted at index: 0
1 is inserted at index: 0
2 is inserted at index: 2
3 is inserted at index: 3
9 is inserted at index: 6
11 is inserted at index: 7
insert to the most right position
0 is inserted at index: 0
1 is inserted at index: 2
2 is inserted at index: 3
3 is inserted at index: 3
5 is inserted at index: 5
9 is inserted at index: 6
11 is inserted at index: 7

We tested the implementation across various cases, and all results were correct.

Visualization

Only demonstrate left-most insertion. Right-most insertion is the same.

Scenario1

The inserted number x: a < x < b

Scenario2

The inserted number x: a == x < b

Scenario3

The inserted number x: a < x == b

Scenario4

The inserted number x: a == x == b

Binary Search Insertion With Duplicate Elements

http://chuzcjoe.github.io/2024/09/15/misc-binary-insert/

Author

Joe Chu

Posted on

2024-09-15

Updated on

2025-01-09

Licensed under

Comments