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 PHP

1 Answer

0 votes
function findStartingEndingPosition($arr, $value) {
    $result = array_fill(0, 2, -1);

    $i = 0;
    for (; $i < count($arr) - 1; $i++) {
        if ($arr[$i] == $value) {
            $result[0] = $i;
            $result[1] = $i;
            break;
        }
    }
    
    for ($j = $i; $j < count($arr) - 1; $j++) {
        if ($arr[$j] == $arr[$j + 1]) {
            $result[1] = $j + 1;
        }
        else {
            break;
        }
    }
    
    return $result;
}

$arr = array(1, 3, 4, 7, 7, 8, 8, 10, 11);
$value = 8;

$result = findStartingEndingPosition($arr, $value);

echo "start: " . $result[0] . "\n";
echo "end: " . $result[1] . "\n";



/*
run:

start: 5
end: 6

*/

 



answered Mar 30, 2024 by avibootz
...