Overview and Notes: 3.10 - Lists

  • Lists are a number of items that is refered to by an index
    • In most languages, the index start at 0 (but it starts at 1 for collegeboard)
  • Lists can be used to store a large amounts of information that would've required a lot of variables to store

Fill out the empty boxes:

Pseudocode Operation Python Syntax Description
aList[i] aList[i] Accesses the element of aList at index i
x ← aList[i] x = aList[i] Assigns the element of aList at index i
to a variable 'x'
aList[i] ← x aList(i) = x Assigns the value of a variable 'x' to
the element of a List at index i
aList[i] ← aList[j] aList[i] = aList[j] Assigns value of aList[j] to aList[i]
INSERT(aList, i, value) aList.insert(i, value) value is placed at index i in aList. Any
element at an index greater than i will shift
one position to the right.
APPEND(aList, value) aList.append(value) Adds value at the very end of the list, length of List increases by 1
REMOVE(aList, i) aList.pop(i)
OR
aList.remove(value)
Removes item at index i and any values at
indices greater than i shift to the left.
Length of aList decreased by 1.

Overview and Notes: 3.8 - Iteration

  • Iteration is the repetition of a particular set of algorithm
    • Conditional Iteration is iterations that only stops when a condition is met, often using if statements
  • Iteration is often done using loops
    • Also often uses lists or dictionaries
  • Nested loops is useful for iterating inside a iteration

Homework Assignment

Instead of us making a quiz for you to take, we would like YOU to make a quiz about the material we reviewed.

We would like you to input questions into a list, and use some sort of iterative system to print the questions, detect an input, and determine if you answered correctly. There should be at least five questions, each with at least three possible answers.

You may use the template below as a framework for this assignment.

import random
questions = []

def questionloop():
    asking=True
    while asking:
        question=input("Please add a question: ")
        ansCount=int(input("Enter how many options do you want: "))
        answers=[]
        for i in range(ansCount):
            answer=input("Enter a Answer: ")
            answers.append(answer)
        correctAns=int(input("Enter the correct ans (in number): "))
        questions.append([question,answers,correctAns])
        asking=input("Add more questions? (Y/N)")=="Y"

def answercheck():
    score=0
    total=0
    random.shuffle(questions)
    for question in questions:
        print(question[0])
        for i in range(len(question[1])):
            print(str(i+1)+". "+question[1][i])
        if input()==question[2]:
            score+=1
        total+=1
        print("Your score is "+str(score)+'/'+str(total))
    if (score/total>0.6):
        print("You passed the test!")
    else:
        print("You didn't pass the test...")

questionloop()
answercheck()

Hacks

Here are some ideas of things you can do to make your program even cooler. Doing these will raise your grade if done correctly.

  • Add more than five questions with more than three answer choices ✓
  • Randomize the order in which questions/answers are output ✓
  • At the end, display the user's score and determine whether or not they passed ✓

Challenges

Important! You don't have to complete these challenges completely perfectly, but you will be marked down if you don't show evidence of at least having tried these challenges in the time we gave during the lesson.

3.10 Challenge

Follow the instructions in the code comments.

grocery_list = ['apples', 'milk', 'oranges', 'carrots', 'cucumbers']

# Print the fourth item in the list
print(grocery_list[3])

# Now, assign the fourth item in the list to a variable, x and then print the variable
grocery_3=grocery_list[3]
print(grocery_3)

# Add these two items at the end of the list : umbrellas and artichokes
grocery_list.append("umbrellas")
grocery_list.append("artichokes")


# Insert the item eggs as the third item of the list 
grocery_list.insert(2,"eggs")

# Remove milk from the list 
grocery_list.remove("milk")

# Assign the element at the end of the list to index 2. Print index 2 to check
grocery_list[2]=grocery_list[-1]
print(grocery_list[2])

# Print the entire list, does it match ours ? 
print(grocery_list)

# Expected output
# carrots
# carrots
# artichokes
# ['apples', 'eggs', 'artichokes', 'carrots', 'cucumbers', 'umbrellas', 'artichokes']
carrots
carrots
artichokes
['apples', 'eggs', 'artichokes', 'carrots', 'cucumbers', 'umbrellas', 'artichokes']

3.8 Challenge

Create a loop that converts 8-bit binary values from the provided list into decimal numbers. Then, after the value is determined, remove all the values greater than 100 from the list using a list-related function you've been taught before. Print the new list when done.

Once you've done this with one of the types of loops discussed in this lesson, create a function that does the same thing with a different type of loop.

binarylist = [
    "01001001", "10101010", "10010110", "00110111", "11101100", "11010001", "10000001"
]

def binary_convert(binary):
    ansList=[]
    for bin in binary:
        ans=0
        for i in range(8):
            ans+=int(bin[i])*2**(8-i-1)
        ansList.append(ans)
    
    ind=0
    while ind<len(ansList):
        if ansList[ind]>100:
            ansList.pop(ind)
        else:
            ind+=1
    return ansList

print(binary_convert(binarylist))
[73, 55]