|   |     | 
| (134 intermediate revisions by 5 users not shown) | 
| Line 1: | Line 1: | 
|  | This page contains notes and discussions related to the SCS Curriculum Reinvention Committee. |  | This page contains notes and discussions related to the SCS Curriculum Reinvention Committee. | 
|  | 
 |  | 
 | 
|  | The content below has gratuitous markup so as to make it obvious how to add morestuff.
 |  | =Requests for more data= | 
|  | 
 |  | 
 | 
|  | To edit this page, you first need to create an account - click thelink inthe top-right ofthe page. Then click on the edit tab just about the page headline. Or,you can edit individual sections.
 |  | *Why are students leaving SCS? | 
|  |  | **What are the grades in SCS-related courses for students who change majors out of SCS? | 
|  |  | **What majors do they switch to?  After how many terms? | 
|  |  | *DFW and A/B rates for 2009/2010 versus past years in 1405, 1406, 1805? | 
|  | 
 |  | 
 | 
|  | =COMP 1405/1406 Redesign= |  | =Courses to be examined= | 
|  | 
 |  | 
 | 
|  | ==Topic Brainstorming==
 |  | Introductory Programming | 
|  |  | *COMP 1405 - Introduction to Object-Oriented Programming | 
|  |  | *COMP 1406 - Design and Implementation of Computer Applications | 
|  | 
 |  | 
 | 
|  | Add topics here at the end ofthe section.  Please ''don't'' '''remove''' anything!
 |  | Theory | 
|  |  | *COMP 1805 - Discrete Structures | 
|  |  | *COMP 2805 - Introduction to Theory of Computation | 
|  |  | *COMP 2402 - Abstract Data Types and Algorithms | 
|  |  | *COMP 3804 - Design and Analysis of Algorithms I | 
|  | 
 |  | 
 | 
|  | * WHAT IS COMPUTER SCIENCE
 |  | Intermediate Programming | 
|  | ** problem solving
 |  | *COMP 1402 - Introduction to Systems Programming | 
|  | ** algorithms
 |  | *COMP 2404 - Programming in C++ | 
|  | ** abstraction and problem decomposition
 |  | 
|  | ** efficiency ??
 |  | 
|  | * PSEUDO-CODE ?? |  | 
|  | * SEQUENCING INSTRUCTIONS
 |  | 
|  | ** top down coding in sequence (e.g., draw a house)
 |  | 
|  | * VARIABLES
 |  | 
|  | ** declaring vs. assigning
 |  | 
|  | ** memory usage ??
 |  | 
|  | ** constants
 |  | 
|  | ** examples:
 |  | 
|  | *** compute simple math formulas
 |  | 
|  | *** interactive input (e.g., use mouse position)
 |  | 
|  | *** motion (if doing graphics)
 |  | 
|  | * Numbers
 |  | 
|  | ** integers
 |  | 
|  | ** floats
 |  | 
|  | * CONDITIONALS
 |  | 
|  | ** simple IF/ELSE
 |  | 
|  | ** nested IF
 |  | 
|  | ** booleans(AND/OR)
 |  | 
|  | ** examples:
 |  | 
|  | *** make choices based on runtime input
 |  | 
|  | *** basic state machine
 |  | 
|  | *** edge cases / error checking
 |  | 
|  | * ITERATION
 |  | 
|  | ** repeating X times (REPEAT)
 |  | 
|  | ** counting (FOR)
 |  | 
|  | ** repeating until condition (WHILE)
 |  | 
|  | ** nested loops
 |  | 
|  | ** examples
 |  | 
|  | *** sum/avg/max/min
 |  | 
|  | *** counting matches
 |  | 
|  | *** MonteCarlo approximation
 |  | 
|  | *** loop until user input
 |  | 
|  | *** searching (find first match)
 |  | 
|  | * ARRAYS (1D and 2D)
 |  | 
|  | ** initializing and memory usage
 |  | 
|  | ** simple 1D (sum.avg/max/min)
 |  | 
|  | ** insert/remove
 |  | 
|  | ** copy/growing array
 |  | 
|  | * Optimization
 |  | 
|  | ** e.g., knapsack
 |  | 
|  | ** greedy
 |  | 
|  | * Simulation
 |  | 
|  | ** virus clearing
 |  | 
|  | ** Roomba
 |  | 
|  | * Abstract data types
 |  | 
|  | * Sorting
 |  | 
|  | * Search
 |  | 
|  | ** linear
 |  | 
|  | ** binary
 |  | 
|  | ** exhaustive
 |  | 
|  | * Divide and conquer
 |  | 
|  | * Dynamic programming
 |  | 
|  | * FORMATTING
 |  | 
|  | ** string manipulation
 |  | 
|  | ** display in columns (i.e., tabbing)
 |  | 
|  | ** display dates/times
 |  | 
|  | * Data structures
 |  | 
|  | ** lists
 |  | 
|  | ** structures
 |  | 
|  | ** tuples
 |  | 
|  | ** binary trees
 |  | 
|  | ** dictionaries
 |  | 
|  | ** sets
 |  | 
|  | ** stacks, queues
 |  | 
|  | * Complexity analysis
 |  | 
|  | ** informal
 |  | 
|  | * OBJECTS
 |  | 
|  | ** instance variables
 |  | 
|  | ** initialization (constructors)
 |  | 
|  | ** shared references
 |  | 
|  | ** static vs. instance
 |  | 
|  | * FUNCTIONS and PROCEDURES
 |  | 
|  | ** simple computations and return values
 |  | 
|  | ** passing parameters
 |  | 
|  | ** passing arrays as parameters
 |  | 
|  | ** helper methods
 |  | 
|  | * RECURSION (likely 1406 material?)
 |  | 
|  | ** inductive definitions of data and associated recursion patterns.
 |  | 
|  | ** direct vs. indirect
 |  | 
|  | ** tail recursion
 |  | 
|  | ** examples:
 |  | 
|  | *** math problems (factorial/sum/avg)
 |  | 
|  | *** searching mazes
 |  | 
|  | *** iterate a non recursive data structure (array)
 |  | 
|  | *** iterate a recursive data structure (e.g., tree)
 |  | 
|  | * PERSISTENCE (likely 1406 material?)
 |  | 
|  | ** writing files
 |  | 
|  | ** reading files
 |  | 
|  | ** parsing files
 |  | 
|  | * WINDOWING
 |  | 
|  | ** display text output
 |  | 
|  | ** get textfield input
 |  | 
|  | ** buttons
 |  | 
|  | ** design and layout
 |  | 
|  | ** handling events
 |  | 
|  | ** menus
 |  | 
|  | ** dialog boxes
 |  | 
|  | * GRAPHICS
 |  | 
|  | ** drawing with lines/shapes |  | 
|  | ** grabbing/selecting/moving graphical objects
 |  | 
|  | * User interaction
 |  | 
|  | * PROPER CODING STYLE
 |  | 
|  | ** encapsulation
 |  | 
|  | ** polymorphism
 |  | 
|  | ** private/public/protected data
 |  | 
|  | * INHERITANCE
 |  | 
|  | ** class hierarchies
 |  | 
|  | ** abstract vs. concrete classes ?
 |  | 
|  | ** overriding/inheriting methods
 |  | 
|  | ** type-casting (needed if JAVA used) ?
 |  | 
|  | * NETWORKING ?? (1406 ... as interesting examples)
 |  | 
|  | ** read internet page
 |  | 
|  | ** two applications talk over network
 |  | 
|  | * Event-driven programming
 |  | 
|  | * Model-View-Controller (more for 1406)
 |  | 
|  | * Database APIs
 |  | 
|  | ** Allow use of key/value stores as used by standard websites
 |  | 
|  | * Testing and debugging
 |  | 
|  | ** design vs. implementation errors
 |  | 
|  | ** basic test cases, regression testing?
 |  | 
|  | ** basic debugger usage
 |  | 
|  | ** strategies for identifying and fixing programming problems
 |  | 
|  | * Software licenses
 |  | 
|  | ** open source and commercial
 |  | 
|  | ** restrictions on reuse
 |  | 
|  | * How to read code
 |  | 
|  | * editing and building software
 |  | 
|  | ** basic IDE usage
 |  | 
|  | * commenting, code formatting guidelines
 |  | 
|  | * revision control
 |  | 
|  | ** have students grab class code from this, pull updates
 |  | 
|  | ** make commits/push to submit?
 |  | 
|  | * Understanding APIs
 |  | 
|  | ** basic idea of contract, side effects
 |  | 
|  | * Concurrency/parallel code
 |  | 
|  | ** maybe not standard locking but some clean parallel constructs?
 |  | 
|  | * Relative costs of operations
 |  | 
|  | ** memory vs. I/O vs. computation
 |  | 
|  | ** very basic benchmarking
 |  | 
|  | ** main idea: know that you can't predict what is going to be fast inpractice w/o tests
 |  | 
|  | 
 |  | 
 | 
|  | * my first wiki entry ever!  -djh |  | Other Core-ish Courses | 
|  |  | *COMP 2003 - Computer Organization | 
|  |  | *COMP 2405 - Internet Application Programming | 
|  |  | *COMP 3000 - Operating Systems | 
|  |  | *COMP 3002 - Compiler Construction | 
|  |  | *COMP 3004 - Object-Oriented Software Engineering | 
|  |  | *COMP 3005 - Database Management Systems | 
|  |  | *COMP 3007 - Programming Paradigms | 
|  |  | *COMP 3008 - User Interface Architecture | 
|  |  | *COMP 3203 - Principles of Computer Networks | 
|  |  | *STAT 2507 | 
|  |  | *STAT 2605 | 
|  | 
 |  | 
 | 
|  | Should we copy the [http://ocw.mit.edu/OcwWeb/Electrical-Engineering-and-Computer-Science/6-00Fall-2008/CourseHome/  MIT 6.00 outline] here?
 |  | =Detailed Discussions= | 
|  | 
 |  | 
 | 
|  | ===Sub categories?===
 |  | *[[CR: COMP 1405/1406 Redesign|COMP 1405/1406 Redesign]] | 
|  | Yes, we can add sub categories here.
 |  | *[[CR: Theory course redesign|Theory course redesign]] | 
|  |   |  | *[[CR: Other CS approaches to Math/Theory]] | 
|  | ==COMP1405 LIST OF TOPICS (UNORDERED) FOR WEEKLY OUTLINE (Mark's Opinion)==
 |  | *[[CR: New course descriptions and rationale|New course descriptions and rationale]] | 
|  |   |  | *[[CR: Survey of theory requirements in other Canadian Honours programs|Theory requirements survey]] | 
|  | * WHAT IS COMPUTER SCIENCE |  | *[[CR: Reducing the Core Size|Reducing the Core Size]] | 
|  | ** problem solving
 |  | *[[CR: Learning Objectives]] | 
|  | ** algorithms
 |  | *[[CR: Proposal to Faculty May 2011]] | 
|  | ** abstraction and problem decomposition
 |  | *[[CR: stream changes]] | 
|  | ** divide and conquer
 |  | *[[CR: Proposal to Faculty September 2011]] | 
|  | ** efficiency (just an intro to the ideas behind it)
 |  | *[[CR: Third and Fourth Year]] | 
|  | * PSEUDO-CODE
 |  | *[[CR: Attracting advanced students]] | 
|  | * SEQUENCING INSTRUCTIONS
 |  | *[[CR: Curriculum Changes April 2012]] | 
|  | ** top down coding in sequence (e.g., draw a house)
 |  | *[[CR: to do list]] | 
|  | * VARIABLES
 |  | *[[CR: Notes Fall 2012]] | 
|  | ** declaring vs. assigning
 |  | *[[CR: New 3rd year courses]] | 
|  | ** memory usage (how memory is affected)
 |  | *[[CR: Curriculum Changes for 2015/2016]] | 
|  | ** constants
 |  | *[[CR: Winter 2014]] | 
|  | ** examples:
 |  | *[[CR: Summer 2014]] | 
|  | *** compute simple math formulas
 |  | 
|  | *** interactive input (e.g., use mouse position)
 |  | 
|  | *** motion (if doing graphics)
 |  | 
|  | * Numbers
 |  | 
|  | ** integers
 |  | 
|  | ** floats
 |  | 
|  | * CONDITIONALS
 |  | 
|  | ** simple IF/ELSE
 |  | 
|  | ** nested IF
 |  | 
|  | ** booleans(AND/OR)
 |  | 
|  | ** examples: |  | 
|  | *** make choices based on runtime input |  | 
|  | *** basic state machine
 |  | 
|  | *** edge cases / error checking
 |  | 
|  | * ITERATION
 |  | 
|  | ** repeating X times (REPEAT)
 |  | 
|  | ** counting (FOR)
 |  | 
|  | ** repeating until condition (WHILE)
 |  | 
|  | ** nested loops
 |  | 
|  | ** examples
 |  | 
|  | *** sum/avg/max/min
 |  | 
|  | *** counting matches
 |  | 
|  | *** MonteCarlo approximation
 |  | 
|  | *** loop until user input
 |  | 
|  | *** searching (find first match)
 |  | 
|  | * COMMENTING / CODE FORMATTING GUIDELINES
 |  | 
|  | * ARRAYS (1D and 2D)
 |  | 
|  | ** initializing and memory usage
 |  | 
|  | ** simple 1D (sum.avg/max/min)
 |  | 
|  | ** insert/remove
 |  | 
|  | ** copy/growing array
 |  | 
|  | * OBJECTS
 |  | 
|  | ** instance variables
 |  | 
|  | ** initialization (constructors)
 |  | 
|  | ** shared references
 |  | 
|  | ** static vs. instance
 |  | 
|  | * FUNCTIONS and PROCEDURES
 |  | 
|  | ** simple computations and return values
 |  | 
|  | ** passing parameters
 |  | 
|  | ** passing arrays as parameters
 |  | 
|  | ** helper methods
 |  | 
|  | * EVENT-DRIVEN PROGRAMMING (if using Processing)
 |  | 
|  | * GRAPHICS (if using Processing)
 |  | 
|  | ** drawing with lines/shapes
 |  | 
|  | ** grabbing/selecting/moving graphical objects
 |  | 
|  | * USER INTERACTION
 |  | 
|  | * RELATIVE COSTS OF OPERATIONS
 |  | 
|  | ** memory vs. I/O vs. computation
 |  | 
|  | ** very basic benchmarking
 |  | 
|  | ** main idea:know that you can't predict what is going tobe fast in practice w/o tests
 |  | 
|  | * SORTING |  | 
|  | * SEARCH
 |  | 
|  | ** linear
 |  | 
|  | ** binary
 |  | 
|  | ** exhaustive
 |  | 
|  | * SIMULATION
 |  | 
|  | ** virus clearing
 |  | 
|  | ** Roomba
 |  | 
|  | * HOW TO READ CODE ???
 |  | 
|  |   |  | 
|  | ==COMP1406 LIST OF TOPICS (UNORDERED) FOR WEEKLY OUTLINE (Mark's Opinion)==
 |  | 
|  |   |  | 
|  | * EDITING AND BUILDING SOFTWARE
 |  | 
|  | ** basic IDE usage
 |  | 
|  | * RECURSION
 |  | 
|  | ** inductive definitions of data and associated recursion patterns.
 |  | 
|  | ** direct vs. indirect
 |  | 
|  | ** tail recursion
 |  | 
|  | ** examples:
 |  | 
|  | *** math problems (factorial/sum/avg)
 |  | 
|  | *** searching mazes
 |  | 
|  | *** iterate a non recursive data structure (array)
 |  | 
|  | *** iterate a recursive data structure (e.g., tree)
 |  | 
|  | * PERSISTENCE
 |  | 
|  | ** writing files
 |  | 
|  | ** reading files
 |  | 
|  | ** parsing files
 |  | 
|  | * WINDOWING
 |  | 
|  | ** display text output
 |  | 
|  | ** get textfield input
 |  | 
|  | ** buttons
 |  | 
|  | ** design andlayout
 |  | 
|  | ** handling events
 |  | 
|  | ** menus
 |  | 
|  | ** dialog boxes
 |  | 
|  | * EVENT-DRIVEN PROGRAMMING (if not using Processing in 1405)
 |  | 
|  | * MODEL/VIEW/CONTROLLER
 |  | 
|  | * GRAPHICS (if not using Processing in 1405)
 |  | 
|  | ** drawing with lines/shapes
 |  | 
|  | ** grabbing/selecting/moving graphical objects
 |  | 
|  | * PROPER CODING STYLE
 |  | 
|  | ** encapsulation
 |  | 
|  | ** polymorphism
 |  | 
|  | ** private/public/protected data
 |  | 
|  | * INHERITANCE
 |  | 
|  | ** class hierarchies
 |  | 
|  | ** abstract vs. concrete classes ?
 |  | 
|  | ** overriding/inheriting methods
 |  | 
|  | ** type-casting (needed if JAVA used) ?
 |  | 
|  | * NETWORKING
 |  | 
|  | ** read internet page
 |  | 
|  | ** two applications talk over network
 |  | 
|  | * FORMATTING output nicely
 |  | 
|  | ** string manipulation
 |  | 
|  | ** display in columns (i.e., tabbing)
 |  | 
|  | ** display dates/times
 |  | 
|  | * ABSTRACT DATA TYPES / DATA STRUCTURES
 |  | 
|  | ** lists
 |  | 
|  | ** structures
 |  | 
|  | ** tuples
 |  | 
|  | ** binary trees
 |  | 
|  | ** dictionaries
 |  | 
|  | ** sets
 |  | 
|  | ** stacks, queues
 |  | 
|  | * TESTING AND DEBUGGING
 |  | 
|  | ** design vs. implementation errors
 |  | 
|  | ** basic test cases, regression testing?
 |  | 
|  | ** basic debugger usage
 |  | 
|  | ** strategies for identifying andfixing programming problems
 |  | 
|  | * OPTIMIZATION |  | 
|  | ** e.g., knapsack
 |  | 
|  | ** greedy
 |  | 
|  | * DYNAMIC PROGRAMMING
 |  | 
|  |   |  | 
|  | ==EXTRA LIST OF TOPICS TO ADD IF TIME PERMITS (Mark's Opinion)==
 |  | 
|  |   |  | 
|  | * UNDERSTANDING APIs
 |  | 
|  | ** basic idea ofcontract, side effects
 |  | 
|  | * DATABASE APIs ??? |  | 
|  | ** Allow use of key/value stores as used by standard websites
 |  | 
|  | * SOFTWARE LICENSES
 |  | 
|  | ** open source and commercial
 |  | 
|  | ** restrictions on reuse
 |  | 
|  | * REVISION CONTROL
 |  | 
|  | ** have students grab class code from this, pull updates
 |  | 
|  | ** make commits/push to submit?
 |  | 
|  | * CONCURRENCY/PARALLEL CODE
 |  | 
|  | ** maybe not standard locking but some clean parallel constructs?
 |  | 
|  |   |  | 
|  | ==Sample weekly outline (Fall 2006)==
 |  | 
|  |   |  | 
|  | 1. Introduction
 |  | 
|  | Sept 7-8
 |  | 
|  |      - intro to CS
 |  | 
|  |      - class stuff
 |  | 
|  |   |  | 
|  | 2. Algorithms
 |  | 
|  | Sept 11-15
 |  | 
|  |      - what are they
 |  | 
|  |      - intro to problem solving
 |  | 
|  |      - statements
 |  | 
|  |      - pseudocode
 |  | 
|  |   |  | 
|  | 3. Variables
 |  | 
|  | Sept 18-22
 |  | 
|  |      - concept
 |  | 
|  |      - identifiers
 |  | 
|  |      - assignment
 |  | 
|  |      - expressions, arithmetic
 |  | 
|  |   |  | 
|  | 4. Conditionals
 |  | 
|  | Sept 25-29
 |  | 
|  |      - Decision statements
 |  | 
|  |      - boolean operators
 |  | 
|  |      - if / then / else
 |  | 
|  |      - case / switch
 |  | 
|  |      - going from problem description to conditional statement
 |  | 
|  |   |  | 
|  | 5. Iteration
 |  | 
|  | Oct 2-6
 |  | 
|  |      - idea of looping
 |  | 
|  |      - starting / stopping / stepping
 |  | 
|  |      - loop bodies
 |  | 
|  |      - top and bottom loops
 |  | 
|  |      - for loops
 |  | 
|  |      - while loops
 |  | 
|  |      - going from problem to loop statements
 |  | 
|  |   |  | 
|  | 6. Subprograms
 |  | 
|  | Oct 9-13
 |  | 
|  |      - idea of modularization
 |  | 
|  |      - functions and procedures
 |  | 
|  |      - parameter passing
 |  | 
|  |      - variable scope
 |  | 
|  |      - when to modularize (problem solving)
 |  | 
|  |   |  | 
|  | 7. Computer architecture
 |  | 
|  | Oct 16-20
 |  | 
|  |      - basic von Neumann architecture
 |  | 
|  |      - linear memory organization
 |  | 
|  |      - possibly midterm post-mortem in this week
 |  | 
|  |   |  | 
|  | 8. Data structures 1:Arrays
 |  | 
|  | Oct 23-27
 |  | 
|  |      - idea of data structures & collections
 |  | 
|  |      - arrays & linear memory
 |  | 
|  |      - array operations, initialization
 |  | 
|  |      - relation to loops
 |  | 
|  |      - 2D arrays
 |  | 
|  |      - going from problem to array specification
 |  | 
|  |   |  | 
|  | 9. Data structures 2: Structs
 |  | 
|  | Oct 30-Nov 3
 |  | 
|  |      - idea of user-defined structures
 |  | 
|  |      - why and when to use
 |  | 
|  |      - examples
 |  | 
|  |   |  | 
|  | 10. Searching
 |  | 
|  | Nov 6-10
 |  | 
|  |      - a larger problem domain
 |  | 
|  |      - linear and binary search
 |  | 
|  |      - 'putting it all together' (arrays, loops, variables, etc)
 |  | 
|  |      - introduction to algorithm analysis (just theidea that different
 |  | 
|  | algorithms can take different time)
 |  | 
|  |   |  | 
|  | 11. Sorting
 |  | 
|  | Nov 13-17
 |  | 
|  |      - same basic structure as searching week
 |  | 
|  |      - bubble sort and selection sort
 |  | 
|  |   |  | 
|  | 12. Recursion
 |  | 
|  | Nov 20-24
 |  | 
|  |      - introduction to theidea
 |  | 
|  |      - base cases & recursive cases
 |  | 
|  |      - composition steps (returning a value)
 |  | 
|  |   |  | 
|  | 13. Review
 |  | 
|  | Nov 27-Dec 4
 |  | 
|  |      - lab exam postmortem
 |  | 
|  |      - review for the final
 |  | 
|  |   |  | 
|  | ==Textbooks==
 |  | 
|  | * Sedgewick and Wayne, [http://www.cs.princeton.edu/introcs/home/ Introduction toProgramming in Java] |  | 
|  |   |  | 
|  | ==Assigned Problems (processing and other)==
 |  | 
|  | Draw a face, draw a house, draw a robot. (basic straight-line code)
 |  | 
|  |   |  | 
|  | Logical drawing (draw simple forms based on mouse position)
 |  | 
|  | [[File:Example.jpg]] |  | 
|  |   |  | 
|  | Using for loops to augment drawing.
 |  | 
|  |   |  | 
|  | Grass:
 |  | 
|  |   |  | 
|  | [[File:Example.jpg]] |  | 
|  |   |  | 
|  | Stars:
 |  | 
|  |   |  | 
|  | [[File:Example.jpg]] |  | 
|  | - change the size, color distribution of stars
 |  | 
|  | - draw stars only above the horizon
 |  | 
|  | - draw stars only inside a circle (telescope view)
 |  | 
|  |   |  | 
|  | - add freckles to the face, hair
 |  | 
|  |   |  | 
|  | Skyscraper:
 |  | 
|  | - drawing location based on loop variable
 |  | 
|  | [[File:Example.jpg]] |  | 
|  |   |  | 
|  | variants: some windows dark, some lit
 |  | 
|  |   |  | 
|  | draw entire city (collection of buildings)
 |  | 
|  |   |  | 
|  | base sky color and window distribution on mouse pointer (windows get dark as it gets later)
 |  | 
|  |   |  | 
|  | Simple image processing:
 |  | 
|  |   |  | 
|  | Convert colored image to greyscale
 |  | 
|  |   |  | 
|  | Convert image to black and white; variant: base proportion of blackness on mouse position
 |  | 
|  |   |  | 
|  | [[File:Example.jpg]] |  | 
|  |   |  | 
|  | Convert image to red and white -- only keep red pixels (problem:how todefine?)
 |  | 
|  |   |  | 
|  | Robot behaviour:
 |  | 
|  |   |  | 
|  | Move small robot image or drawing primitive based on obstacles, mouse pointer
 |  | 
|  | - e.g., flee from mouse
 |  | 
|  | - e.g., attracted to mouse
 |  | 
|  | - e.g., want to maintain certain distance from mouse
 |  | 
|  |   |  | 
|  | ==Paper problem solving examples==
 |  | 
|  |   |  | 
|  | *Suppose you have two jugs, one with a capacity of three liters and the other with a capacity of five liters. Write an algorithm that uses these two jugs, and no other measuring devices, to get exactly one liter of water in the five-gallon jug. |  | 
|  |   |  | 
|  | * The Greeks of classical Athens assemble to choose a new leader, and they vote by placing voting stones into an urn:a black stone, to vote for Castor, or a white stone, to vote for Pollux. You are put in charge of the election results. Write a specific algorithm for determining which of the candidates (Castor or Pollux) is the winner.
 |  | 
|  |   |  | 
|  | * You are the in charge of the Royal mint, which produces a single type coin, the grote. There are ten machines producing grotes. One machine is producing grotes weighing one gram less than they should (each coin should weigh 10 grams). You have a scale that can be used exactly once before it explodes (don't ask), but will give an accurate reading of the weight of whatever is on the scale. Using only this one weighing, identify the single faulty machine. (Note; no algorithm required, just solve the puzzle if you can). |  | 
|  |   |  | 
|  | * The Royal Mint has run out of exploding scales, and now has balances instead. (A balance will tell you whether the items in the left pan or the items in the right pan are heavier, but not how much heavier.) You have nine grote-minting machines, and one of them is producing grotes that are too light. Write an algorithm for using the balance to determine which machine's grotes are too light. (Challenge:do it with only two balance operations.)
 |  | 
|  |   |  | 
|  | * Four travellers are trying to cross an old, rickety bridge, so decrepit that only two can cross at once. They reached the bridge at night, and have only one flashlight among them; there are enough holes in the bridge that it can only be crossed safely by a group carrying a light. Now, the travellers have reached the bridge at different levels of exhaustion:one will take 1 minute to walk across; one will take 2 minutes; one will take 5 minutes to limp across; and one will take 10 minutes to crawl across. A group moves at the speed of its slowest member. Give a general algorithm forgetting everyone safely to the far side of the bridge. Using your algorithm, how long does it take the travellers to cross? (There are no tricks, like throwing the flashlight back to the other side.) (Challenge: get the group across in under 20 minutes.) (Challenge #2: get the group across in under 18 minutes.) |  | 
|  |   |  | 
|  | * An old story has a grateful king granting a wish to a favored advisor, and the advisor describing the following process. A chess board is to be brought out, and one grain of rice placed on the first square, two grains on the second, four on the third, and so on, doubling for each square. There are 64 squares on the chessboard. Write pseudocode for an algorithm to determine how many pounds of rice the unlucky king has to give to the advisor, assuming 1000 grains per pound. |  | 
|  |   |  | 
|  | * Suppose you are trying to pay off credit card debt. You have an initial balance, and the credit card charges 1.5% additional interest each month. Write pseudocode for an algorithm that gets a monthly payment amount from the user and then reports (a) how long it will take to pay off the debt; (b) how much of the payment is for interest (total paid minus initial balance). Make sure not to allow infinite loops! (How would a bank avoid an infinite loop on a credit card?)
 |  | 
|  |   |  | 
|  | * You have a spaceship that runs on gold, consuming 1 ton of gold for each parsec traveled. It can carry a maximum of 1000 tons, but can also eject gold into space and pick it up later. You have 3000 tons of gold and want to get as much as possible to your destination 1000 parsecs away (just at the limits of what you could reach, arriving empty). Describe a general algorithm for getting to your destination with as much gold as you can. (Challenge:reach the destination with more than 425 tons.)
 |  | 
|  |   |  | 
|  | * Consider the following exchange: |  | 
|  | **``My dog is precisely one-third Dalmatian.''
 |  | 
|  | **``How can that be?''
 |  | 
|  | **``Well, his father was one-third Dalmatian, and his mother is one-third Dalmatian, and so he is too.''
 |  | 
|  | What is wrong with the reasoning in the last statement? (Note: this is a question about recursion, NOT genetics! Pretend that the amount of Dalmatian in the offspring is the average of the amounts in the parents.)
 |  | 
|  |   |  | 
|  | * The Greek hero Achilles has the ability to stride half the distance to his goal in just a single step. He also has the ability to take a normal step, which will take him at most 1 meter. Write pseudocode for a recursive function that takes a float argument (the initial distance to the goal) and returns the smallest number of steps Achilles has to take to reach his goal. Notice that Achilles's best strategy will be to take giant steps (halving the distance) until the distance remaining is one meter or less, which he can finish with one normal step.
 |  |