PHP - Ds Map::ksorted() Function



The PHP Ds\Map::ksorted() function is used to retrieve a copy of the current map sorted by the key.

The default sorting order of the keys is ascending. However, you can pass an optional comparison function that compares the arguments and returns an integer value less than, equal to, or greater than zero if the first argument is respectively less than, equal to, and greater than the second argument.

Syntax

Following is the syntax of the PHP Ds\Map::ksorted() function −

public Ds\Map::ksorted(callable $comparator = ?): Ds\Map

Parameters

Following is the parameter of this function −

  • comparator − An optional comparison function compares the specified arguments.

Following is the syntax of the comparator function −

callback(mixed $a, mixed $b): int

Return value

This function returns a copy of the map, sorted by key.

Example 1

The following program demonstrates the usage of the PHP Ds\Map::ksorted() function −

<?php 
   $map = new \Ds\Map([2 => 20, 1 => 10, 3 => 30]);
   echo "The map elements are: \n";
   print_r($map);
   echo "The sorted map by key: \n"; 
   #using the ksorted() function
   print_r($map->sorted());
?> 

Output

The above program produces the following output −

The map elements are:
Ds\Map Object
(
    [0] => Ds\Pair Object
        (
            [key] => 2
            [value] => 20
        )

    [1] => Ds\Pair Object
        (
            [key] => 1
            [value] => 10
        )

    [2] => Ds\Pair Object
        (
            [key] => 3
            [value] => 30
        )

)
The sorted map by key:
Ds\Map Object
(
    [0] => Ds\Pair Object
        (
            [key] => 1
            [value] => 10
        )

    [1] => Ds\Pair Object
        (
            [key] => 2
            [value] => 20
        )

    [2] => Ds\Pair Object
        (
            [key] => 3
            [value] => 30
        )

)

Example 2

Following is another example of the PHP Ds\Map::ksorted() function. We use this function to retrieve the sorted map by the key of this map (["a" => "Tutorials", "c" => "Point", "b" => "India"]) −

<?php 
   $map = new \Ds\Map(["a" => "Tutorials", "c" => "Point", "b" => "India"]);
   echo "The map elements are: \n";
   foreach($map as $key=>$value){
	   echo "[".$key."] = ".$value."\n";
   }
   echo "\nThe sorted map by key: \n"; 
   #using the ksorted() function
   $new_map = $map->ksorted();
   foreach($new_map as $key=>$value){
	   echo "[".$key."] = ".$value."\n";
   }
?>

Output

After executing the above program, it will display the following output −

The map elements are:
[a] = Tutorials
[c] = Point
[b] = India

The sorted map by key:
[a] = Tutorials
[b] = India
[c] = Point

Example 3

If an optional comparator function is provided, it compares the map elements and returns an integer value based on the comparison −

<?php  
   $map = new \Ds\Map([2 => 'a', 0 => 'b', 1 => 'c']);
   echo "The map elements are: \n";
   foreach($map as $key=>$value){
	   echo "[".$key."] = ".$value."\n";
   }
   echo "The sorted map by key \n";
   #using ksorted() & comparator function
   $new_map = $map->ksorted(function($a, $b){
	   return $a$b;
   });
   foreach($new_map as $key=>$value){
	   echo "[".$key."] = ".$value."\n";
   } 
?>

Output

Once the above program is executed, it will generate the following output −

The map elements are:
[2] = a
[0] = b
[1] = c
The sorted map by key
[0] = b
[1] = c
[2] = a
php_function_reference.htm
Advertisements