Tracks
/
AWK
AWK
/
Exercises
/
High Scores
High Scores

High Scores

Easy

Instructions

Manage a game player's High Score list.

Your task is to build a high-score component of the classic Frogger game, one of the highest selling and most addictive games of all time, and a classic of the arcade era. Your task is to write methods that return the highest score from the list, the last added score and the three highest scores.

Sorting in AWK

This exercise requires the output to be sorted in a particular way. Like many programming languages, iterating over an array occurs in an implementation-dependent, seemingly random-looking order. This is typically not what humans want to see. GNU awk provides some sorting features.

  1. asort -- sort a numerically indexed array based on the array values.

    #!gawk 
    BEGIN {
        for (i = 1; i <= 5; i++)
            nums[i] = int(100 * rand())
    
        # returns the array size
        n = asort(nums, sorted)
    
        for (i = 1; i <= n; i++)
            print i, nums[i], sorted[i]
    }
    

    which outputs

    1 92 30
    2 59 57
    3 30 59
    4 57 74
    5 74 92
    

    The form n = asort(array) sorts the named array in-place.

    This is most useful for numerically-indexed arrays. The process that populates the sorted array discards the original array indices: the sorted array is indexed from 1 to n.

  2. asorti -- sort an array based on the array indices.

    The asorti function populates a "destination" array containing the "source" array's indices sorted.

    #!gawk
    BEGIN {
        nums["foo"] = int(100 * rand())
        nums["bar"] = int(100 * rand())
        nums["qux"] = int(100 * rand())
    
        print "unordered"
        for (i in nums)
            print i, nums[i]
    
        print "ordered by index"
        n = asorti(nums, sorted)
        for (i = 1; i <= n; i++)
            print sorted[i], nums[sorted[i]]
    }
    

    which outputs

    unordered
    foo 92
    qux 30
    bar 59
    ordered by index
    bar 59
    foo 92
    qux 30
    
  3. PROCINFO["sorted_in"] -- traverse an array in a specified order.

    The builtin PROCINFO array contains a lot of information about the running awk process One interesting element of this array is sorted_in The value of this array key is the name of a function which controls the order in which array indices will be processed by for (indx in array) loops.

    The function can be the name of a user-defined function or there are some handy predefined sorting functions, including:

    • "@ind_str_asc", "@ind_str_desc" - sort the array by index; use alphabetical sorting; sort ascending or descending.
    • "@ind_num_asc", "@ind_num_desc" - sort the array by index; use numerical sorting; sort ascending or descending.
    • "@val_str_asc", "@val_str_desc" - sort the array by value; use alphabetical sorting; sort ascending or descending.
    • "@val_num_asc", "@val_num_desc" - sort the array by value; use numerical sorting; sort ascending or descending.

    The asort example above can be implementented like:

    PROCINFO["sorted_in"] = "@val_num_asc"
    for (idx in nums)
        print idx, nums[idx]
    
    3 30
    4 57
    2 59
    5 74
    1 92
    

    The asorti example can be written:

    PROCINFO["sorted_in"] = "@ind_str_asc"
    for (idx in nums)
        print idx, nums[idx]
    
    bar 59
    foo 92
    qux 30
    

    This method allows us to avoid the temporary sorted array and n return value. Neat and tidy.

User-defined sorting function

The user-defined sorting function takes 4 parameters: the index and value of one array element and the index and value of another array element:

function compare(idx1, val1, idx2, val2) {...}

The return value is:

  • less than zero: idx1 comes before idx2
  • greater than zero: idx1 comes after idx2
  • zero: the indices have the same sorting precedence, but their relative order is undefined.

In addition to PROCINFO["sorted_in"] for controlling for (idx in array) order, both asort and asorti can take the name of a comparison function as a 3rd parameter.

References


Source

Tribute to the eighties' arcade game Frogger
Edit via GitHub The link opens in a new window or tab
AWK Exercism

Ready to start High Scores?

Sign up to Exercism to learn and master AWK with 79 exercises, and real human mentoring, all for free.