Programs are not just for computers: We use them to communicate to
           other people.
        
        
          - 
            Ability to code without typing (on paper/whiteboard)
          
- 
            Understanding correctness of programming
          
- 
            Understanding performance characteristics of programs
          
- 
            Competence with iterative and recursive solutions to problems
          
- 
            Basic object-oriented programming
          
- 
            Use of debuggers
          
- 
            Use of testing
          
          Plus
        
        
          - 
            Understanding of linked lists and resizable arrays 
- 
            Understanding of stacks, queues, dequeues
          
- 
            Understanding of heaps
          
- 
            Understanding of union-find
          
          A data structure is a concrete implementation of an abstract type
        
        
          - 
            For example, linked lists and resizable arrays are data
            structures that could be used to represent the list type
            in python
- 
            Which does python use?  Why?
          


