Welcome to collectivesolver - Programming & Software Q&A with code examples. A website with trusted programming answers. All programs are tested and work.

Contact: aviboots(AT)netvision.net.il

Buy a domain name - Register cheap domain names from $0.99 - Namecheap

Scalable Hosting That Grows With You

Secure & Reliable Web Hosting, Free Domain, Free SSL, 1-Click WordPress Install, Expert 24/7 Support

Semrush - keyword research tool

Boost your online presence with premium web hosting and servers

Disclosure: My content contains affiliate links.

39,926 questions

51,859 answers

573 users

How to find the starting and ending position of a given value in a sorted integer array in JavaScript

2 Answers

0 votes
function findStartingEndingPosition(arr, value) {
    let result = Array(2).fill(-1);

    let i = 0;
    
    for (;i < arr.length - 1; i++) {
        if (arr[i] == value) {
            result[0] = i;
            result[1] = i;
            break;
        }
    }
    
    for (let j = i; j < arr.length - 1; j++) {
        if (arr[j] == arr[j + 1]) {
            result[1] = j + 1;
        }
        else {
            break;
        }
    }
    
    return result;
}
        
const arr = [1, 3, 4, 7, 7, 8, 8, 8, 10, 11];
const value = 8;

const result = findStartingEndingPosition(arr, value);

console.log("start: " + result[0]);
console.log("end: " + result[1]);



/*
run:

start: 5
end: 7

*/

 



answered Mar 30, 2024 by avibootz
edited Mar 30, 2024 by avibootz
0 votes
function findStartingEndingPosition(arr, value) {
    let result = Array(2).fill(-1);

    for (let i = 0; i < arr.length; i++) {
        if (arr[i] !== value) {
            continue;
        }

        if (result[0] === -1) {
            result[0] = i;
        }
        
        result[1] = i;
    }

    return result;
}
        
const arr = [1, 3, 4, 7, 7, 8, 8, 8, 10, 11];
const value = 8;

const result = findStartingEndingPosition(arr, value);

console.log("start: " + result[0]);
console.log("end: " + result[1]);



/*
run:

start: 5
end: 7

*/

 



answered Mar 30, 2024 by avibootz
...