String Arrays
Summary
Materials
Instructional Activities and Classroom Assessments
- Lists (Arrays) Review (5 minutes)
- Introduce String List (Arrays) (15 minutes)
- Activity: Arrays of Strings (30 minutes)
- Reflection/Homework
Learning Objectives
- AAP-1.A Represent a value with a variable. 3.A
- AAP-1.C Represent a list or string using a variable.β3.A
- AAP-1.D For data abstraction:
- AAP-2.N For list operations:
- AAP-2.O For algorithms involving elements of a list:
- CRD-2.Cβ―Identify input(s) to a program.β―3.A
- AAP-3.E For generating random values: - a. Write expressions to generate possible values. 2.B
- b. Evaluate expressions to determine the possible results.β4.B 2.B
 
- AAP-2.B Represent a step-by-step algorithmic process using sequential code statements. 2.B
Essential Knowledge
- AAP-1.A.1 A variable is an abstraction inside a program that can hold a value. Each variable has associated data storage that represents one value at a time, but that value can be a list or other collection that in turn contains multiple values.
- AAP-1.A.2 Using meaningful variable names helps with the readability of program code and understanding of what values are represented by the variables.
- AAP-1.A.3 Some programming languages provide types to represent data, which are referenced using variables. These types include numbers, Booleans, lists, and strings.
- AAP-1.A.4 Some values are better suited to representation using one type of datum rather than another.
- AAP-1.C.1 A list is an ordered sequence of elements. For example, [value1, value2, value3, ...] describes a list where value1 is the first element, value2 is the second element, value3 is the third element, and so on.
- AAP-1.C.2 An element is an individual value in a list that is assigned a unique index.
- AAP-1.C.3 An index is a common method for referencing the elements in a list or string using natural numbers.
- AAP-1.C.4 A string is an ordered sequence of characters.
- AAP-1.D.3 Data abstractions can be created using lists.
- AAP-1.D.4 Developing a data abstraction to implement in a program can result in a program that is easier to develop and maintain.
- AAP-1.D.5 Data abstractions often contain different types of elements.
- AAP-1.D.6 The use of lists allows multiple related items to be treated as a single value. Lists are referred to by different names, such as array, depending on the programming language.
- AAP-2.N.1 The exam reference sheet provides basic operations on lists, including:
 Β§ accessing an element by index Text: aList[i] Block: aList i accesses the element of aList at index i. The first element of aList is at index 1 and is accessed using the notation aList[1].
 Β§ assigning a value of an element of a list to a variable Text: X β aList [i] Block: X aList i assigns the value of aList[i] to the variable X.
 Β§ assigning a value to an element of a list Text: aList[i] β X Block: aList ix assigns the value of X to aList[i]. Text: aList[i] β aList[j] Block: aListaList ij assigns the value of aList[j] to aList[i].
 Β§ inserting elements at a given index Text: INSERT(aList, i, value) Block: aList, i, valueINSERT shifts to the right any values in aList at indices greater than or equal to i. The length of the list is increased by 1, and value is placed at index i in aList.
 Β§ adding elements to the end of the list Text: APPEND(aList, value) Block: APPEND aList, value increases the length of aList by 1, and value is placed at the end of aList.
 Β§ removing elements Text: REMOVE(aList, i) Block: REMOVE aList, i removes the item at index i in aList and shifts to the left any values at indices greater than i. The length of aList is decreased by 1.
 Β§ determining the length of a list Text: LENGTH(aList) Block: LENGTH aList evaluates to the number of elements currently in aList.
- AAP-2.N.2 List procedures are implemented in accordance with the syntax rules of the programming language.
- AAP-2.O.1 Traversing a list can be a complete traversal, where all elements in the list are accessed, or a partial traversal, where only a portion of elements are accessed.
 XEXCLUSIONSTATEMENT(EKAAP-2.O.1): Traversing multiple lists at the same time using the same index for both (parallel traversals) is outside the scope of this course and the AP Exam.
- AAP-2.O.2 Iteration statements can be used to traverse a list.
- AAP-2.O.3 The exam reference sheet provides- Text: FOR EACH item IN aList { <block of statements> }
- Block: FOR EACH item IN aList block of statements
- The variable item is assigned the value of each element of aList sequentially, in order, from the first element to the last element. The code in block of statements is executed once for each assignment of item.
 
- CRD-2.C.2 An event is associated with an action and supplies input data to a program.
- CRD-2.C.3 Events can be generated when a key is pressed, a mouse is clicked, a program is started, or any other defined action occurs that affects the flow of execution.
- AAP-3.E.1 The exam reference sheet provides RANDOM(a, b) Block: RANDOMβ― a, b which generates and returns a random integer from a to b, inclusive. Each result is equally likely to occur. For example, RANDOM(1, 3) could return 1, 2, or 3.β―β―
- AAP-2.B.7 Clarity and readability are important considerations when expressing an algorithm in a programming language.
Details
1. Review Arrays (5 minutes)
- Define lists in computer science.
- Explain how lists are used.
2. Introduction to String Lists (15 minutes)
- Define Lists.
- Explain how string lists are used.
- Demonstrate how to create a string list in MakeCode.
- Practice reducing redundancy with an array of string.
3. Activity: Arrays of Strings (30 minutes)
- Direct students to the Arrays of Strings page.
- Students will go to the Activity: Arrays of Strings webpage.
- Instruct students to complete Tasks 1a and 1b.
- Encourage students to publish their work and paste the links on their Arrays of Strings page.
- If students finish early, encourage students to do the optional extension activities.
4. Reflection/Homework
If you run out of time, you may also assign this as individual homework. Students should complete their reflection.
- Why do we use the length of array instead of just βhard-codingβ the value of the length (for example 4)?
- What is the difference between a For Index and a For Value loop?
- Can you think of any situations where you might prefer the For Index loop when using arrays?