Sheerpower Logo
B.5  Arrays

In sheerpower, arrays are one-origin by default, meaning the first element of an array is indexed as element number one. However, you can change this behavior to zero-origin by using the option base 0 statement.

The dim statement is used to define an array and its size. If you define an array with a size of zero, the array will automatically expand as needed.

dim ages(5) // five reals: 1, 2, 3, 4, and 5 dim names$(5) // five string elements. dim degrees(-50 to 100) // 151 elements from -50 to 100 dim dice(5) // five dice for idx = 1 to 5 dice(idx) = rnd(6) // assign each die a random number between 1 and 6 print 'dice#'; idx;' value '; dice(idx) next idx
Most arrays are single dimensioned. However, multi-dimensional arrays are supported. For example dim weekly_hours(7,24) which would represent 7 days a week, 24 hours a day.

To increase the size of an existing array, let's say from 5 to 10 elements, use the redim statement. And in the example below, let's also use a variable max_ages to both determine the initial and new size of the array:
max_ages = 5 dim ages(max_ages) // five reals: 1, 2, 3, 4, and 5 max_ages = 10 redim ages(max_ages) // Now we have 10 elements

If we don't know how large of an array we need, the syntax for creating a dynamically expanding array is:
dim cash(0) // this is how we create a dynamically expanding array cash(0) = 10.99 cash(0) = 20.50 print 'Cash elements:';size(cash) print
Note: Although arrays are pretty easy to use, nowadays using cluster arrays is preferred since they are just as fast and easy to use and much more versatile. See Cluster arrays for details.
Hide Description

    

       


      

Enter or modify the code below, and then click on RUN

Looking for the full power of Sheerpower?
Check out the Sheerpower website. Free to download. Free to use.
Wide screen