Difference between revisions of "CSC111 Class Page 2018"

From dftwiki3
Jump to: navigation, search
( )
 
(146 intermediate revisions by the same user not shown)
Line 7: Line 7:
 
----
 
----
 
   
 
   
 +
<br /><br />
 +
<center>
 +
[[CSC111_Final_Exam_2018 | Final Exam]]
 +
</center>
 
<br /><br />
 
<br /><br />
 
====&nbsp;====
 
====&nbsp;====
Line 17: Line 21:
 
|}
 
|}
 
<br />
 
<br />
::{| class="mw-collapsible mw-collapsed" style="width:100%" border="1"
+
::{| class="mw-collapsible " style="width:100%" border="1"
 
|- style="background:#dddddd;"
 
|- style="background:#dddddd;"
 
|width="60%"| '''Topics''': Overview of CSC111
 
|width="60%"| '''Topics''': Overview of CSC111
Line 51: Line 55:
 
|}
 
|}
 
<br />
 
<br />
::{| class="mw-collapsible mw-collapsed" style="width:100%" border="1"
+
::{| class="mw-collapsible " style="width:100%" border="1"
 
|- style="background:#dddddd;"
 
|- style="background:#dddddd;"
 
|width="60%"| '''Topics''': Introduction, Python, Idle, Piazza, Moodle submission
 
|width="60%"| '''Topics''': Introduction, Python, Idle, Piazza, Moodle submission
Line 102: Line 106:
 
|}
 
|}
 
<br />
 
<br />
::{| class="mw-collapsible mw-collapsed" style="width:100%" border="1"
+
::{| class="mw-collapsible " style="width:100%" border="1"
 
|- style="background:#dddddd;"
 
|- style="background:#dddddd;"
 
|width="60%"| '''Topics''':  Chapter 2: variables, definite loops, input, the range function
 
|width="60%"| '''Topics''':  Chapter 2: variables, definite loops, input, the range function
Line 145: Line 149:
 
|}
 
|}
 
<br />
 
<br />
::{| class="mw-collapsible" style="width:100%" border="1"
+
::{| class="mw-collapsible " style="width:100%" border="1"
 
|- style="background:#dddddd;"
 
|- style="background:#dddddd;"
 
|width="60%"| '''Topics''': Arithmetic operators, math functions, main().
 
|width="60%"| '''Topics''': Arithmetic operators, math functions, main().
Line 280: Line 284:
 
|}
 
|}
 
<br />
 
<br />
::{| class="mw-collapsible " style="width:100%" border="1"
+
::{| class="mw-collapsible" style="width:100%" border="1"
 
|- style="background:#dddddd;"
 
|- style="background:#dddddd;"
 
|width="60%"| '''Topics''':  
 
|width="60%"| '''Topics''':  
Line 292: Line 296:
 
:::* indexing in a list
 
:::* indexing in a list
 
:::* how range() works
 
:::* how range() works
:::* functions receiving parameters, &amp; returning values
+
:::* functions receiving parameters, &amp; returning values  
::* [[media:CSC111_2018_Week6b.pdf | slides]]
 
 
 
* '''Wednesday''': <font color="magenta">Midterm Exam</font>, in class, timed, on Moodle, closed notes, closed books, closed Idle.
 
* '''Wednesday''': <font color="magenta">Midterm Exam</font>, in class, timed, on Moodle, closed notes, closed books, closed Idle.
 
* '''Friday'''
 
* '''Friday'''
 +
::* The concept of a Python library
 +
::* Comparing Python to Java
 +
::* Understanding the  [http://eightqueen.becher-sundstroem.de/ N-Queens problem]
 +
::* [[NQueens.py | Solving the N-Queens problem in Python]]
 +
::* [[N-Queens_Problem_in_Java | Solving the N-Queens problem in Java]]
 +
::* [[CSC111 Programs Created in Class 2018| Programs created in class]]
 +
::* [[CSC111_And_now,_something_completely_different|And now, for something completely different...]]
 +
::* [[media:CSC111_2018_Week6.pdf | slides]]
 
|
 
|
*
+
* [[CSC111_Lab_6_2018| Lab 6]]
 +
* No new homework.  Homework 5 due after the break.
 
|
 
|
*  
+
* No new reading assignment this week. 
 
|}
 
|}
 
<br /><br />
 
<br /><br />
 
<tanbox>
 
<tanbox>
 
Spring Break
 
Spring Break
 +
<!--center>[[File:animatedBeach.gif]]</center-->
 +
 
</tanbox>
 
</tanbox>
 
<br /><br />
 
<br /><br />
Line 319: Line 332:
 
::{| class="mw-collapsible " style="width:100%" border="1"
 
::{| class="mw-collapsible " style="width:100%" border="1"
 
|- style="background:#dddddd;"
 
|- style="background:#dddddd;"
|width="60%"| '''Topics''': Processing Files
+
|width="60%"| '''Topics''': Processing Files, Graphics, If Statements
 
|width="15%"| '''Lab/Hw'''
 
|width="15%"| '''Lab/Hw'''
 
|width="25%"| '''Reading'''  
 
|width="25%"| '''Reading'''  
 
|-valign="top"
 
|-valign="top"
 
|
 
|
* '''Monday/Wednesday/Friday'''
+
* '''Monday
 +
::* Back to reading files
 +
::* Writing text files
 +
::* Graphics
 +
::* If statements.  Relational operators
 +
* '''Wednesday'''
 +
::* More graphics, with points, rectangles, circles, text
 +
::* Basics of animation
 +
::* Testing for conditions: the IF statement
 +
* '''Friday'''
 +
::* The If statements (Chapter 7)
 +
::* Examples
 +
::* [[CSC111_Exercises_with_If_Statements_(Python_3)| Exercises with If statements]]
 +
::* Rock, Paper, Scissors
 +
::* [[media:CSC111_2018_Week7.pdf | slides]]
 +
::* [[CSC111 Programs Created in Class 2018| Programs created in class]]
 
|
 
|
*
+
* [[CSC111_Lab_7_2018| Lab 7]]
 +
* [[CSC111_Homework_6_2018| Homework 6 (due 3/30)]]
 
|
 
|
* Chapter 7 in Zelle
+
* Graphics are covered in Chapter 4
 +
* If statements are covered in Chapter 7 in Zelle
 
|}
 
|}
  
Line 345: Line 375:
 
::{| class="mw-collapsible " style="width:100%" border="1"
 
::{| class="mw-collapsible " style="width:100%" border="1"
 
|- style="background:#dddddd;"
 
|- style="background:#dddddd;"
|width="60%"| '''Topics''':  
+
|width="60%"| '''Topics''': If-Statements, Eliza
 
|width="15%"| '''Lab/Hw'''
 
|width="15%"| '''Lab/Hw'''
 
|width="25%"| '''Reading'''  
 
|width="25%"| '''Reading'''  
 
|-valign="top"
 
|-valign="top"
 
|
 
|
* '''Monday/Wednesday/Friday'''
+
* '''Monday'''
 +
::* Boolean Operators (Chapter 8, Section 4)
 +
::* Organization of Graphic Program
 +
::* Dealing with Obstacles
 +
* '''Wednesday'''
 +
::* Eliza
 +
::* Indefinite loops: while loops
 +
* '''Friday'''
 +
::* Indefinite Loops (Chapter 8)
 +
:::* Review for-loops
 +
:::* Nested for-loops
 +
:::* Break &amp; Continue
 +
::* [[media:CSC111_2018_Week8.pdf | slides]]
 +
::* [[CSC111_Programs_Created_in_Class_2018| Programs created in class]]
 
|
 
|
*
+
* [[CSC111_Lab_8_2018| Lab 8]]
 +
* [[CSC111_Homework_7_2018| Homework 7]]
 
|
 
|
* Indefinite loops are covered in Chapter 8 in Zelle.
+
* Indefinite Loops and boolean operators are covered in Chapter 8.
 
|}
 
|}
  
Line 376: Line 420:
 
|-valign="top"
 
|-valign="top"
 
|
 
|
* '''Monday/Wednesday/Friday'''
+
* '''Monday'''
 +
::* Exceptions
 +
::* Programming with Objects and Classes
 +
* '''Wednesday'''
 +
::* Continue with classes
 +
:::* Min/Max of tuples
 +
:::* Die class
 +
:::* Cat class
 +
:::* Global vs local
 +
* '''Friday'''
 +
::* Creating a graphic class for a car
 +
::* [[media:CSC111_2018_Week9.pdf | slides]]
 +
::* [[CSC111_Programs_Created_in_Class_2018| Programs created in class]]
 +
 
 
|
 
|
*
+
* [[CSC111_Lab_9_2018 | Lab 9]]
 +
* [[CSC111_Homework_8_2018 | Homework 8]]
 
|
 
|
 
* Section 7.4 in Zelle, on Exceptions
 
* Section 7.4 in Zelle, on Exceptions
Line 403: Line 461:
 
|-valign="top"
 
|-valign="top"
 
|
 
|
* '''Monday/Wednesday/Friday'''
+
[[File:CatGlasses.gif|right|150px]][[File:flowersSmith.gif|right|150px]][[File:catHat.gif|right|150px]]
 +
* '''Monday'''
 +
::* Image Processing
 +
::* Nested for-loops for image processing
 +
::* Displaying gif images
 +
::* Sweep through an image: vertical sweep, horizontal sweep
 +
::* Changing the color of a pixel
 +
::* Changing the color of all the pixels of an image
 +
::* Grey scales
 +
::* Saturation
 +
* '''Wednesday'''
 +
[[Image:piece.gif|right]][[Image:piece2.gif|right]]
 +
::* More Image transformations
 +
:::* Copy an image
 +
:::* Mirror an image
 +
::* Displaying a chessboard
 +
::* Setting up a game of checkers
 +
<center><videoflash>KpMPHhzZzH4</videoflash></center>
 +
* '''Friday'''
 +
::* Continue with the game of checkers
 +
:::* Using objects made of 2 circles
 +
:::* Using a gif image for a piece
 +
:::* Moving checkers on the board
 +
:::* Removing checkers from the board
 +
:::* Adding a Quit button to the game
 +
::* Lists of Lists (Chapter 11)
 +
:::* Sorting
 +
:::* Reversing
 +
:::* Removing duplicates
 +
::* Sorting lists of objects (lists of cats)
 +
::* Filtering data
 +
::* [[CSC111 Programs Created in Class 2018| Programs created in class]]
 +
::* [[media:CSC111_2018_Week10.pdf | slides]]
 
|
 
|
*  
+
* [[CSC111_Lab_10_2018 | Lab 10]]
 +
* [[CSC111_Homework_9_2018 | Homework 9]]
 
|
 
|
*  
+
* Chapter 11, Designing with Lists and Classes
 
|}
 
|}
  
Line 424: Line 515:
 
::{| class="mw-collapsible " style="width:100%" border="1"
 
::{| class="mw-collapsible " style="width:100%" border="1"
 
|- style="background:#dddddd;"
 
|- style="background:#dddddd;"
|width="60%"| '''Topics''': LAM, User Interface, Widgets, Button, digitizing and rendering a Map
+
|width="60%"| '''Topics''': Class inheritance
 
|width="15%"| '''Lab/Hw'''
 
|width="15%"| '''Lab/Hw'''
 
|width="25%"| '''Reading'''  
 
|width="25%"| '''Reading'''  
 
|-valign="top"
 
|-valign="top"
 
|
 
|
* '''Monday/Wednesday/Friday'''
+
* '''Monday'''
 +
::* Lists of Lists
 +
::* [[CSC111 Programs Created in Class 2018| Programs created in class]]
 +
::* [[media:CSC111_2018_Week11.pdf | slides]]
 +
* '''Wednesday'''
 +
::* Class Inheritance
 +
::* Example 1: Super class = GenericCar, derived classes = Taxi, CarWithTop
 +
;:* Example 2: Super class = Rectangle, derived class = RectLabel
 +
::* [[CSC111 Programs Created in Class 2018| Programs created in class]]
 +
::* [[media:CSC111_2018_Week11.pdf | slides]]
 +
* '''Friday'''
 +
[[File:JoeOrourkeQuantumComputing111.png|150px|right|link=https://www.facebook.com/264041891883/photos/a.267301956883.154614.264041891883/10155418103811884/?type=3&theater]]
 +
::* Guest lecture by Prof. Joseph O'Rourke on ''Quantum Computing''
 +
 
 
|
 
|
*
+
* [[CSC111_Lab_11_2018 | Lab 11]]
 +
* [[CSC111_Homework_10_2018 | Homework 10]]
 
|
 
|
*  
+
* Chapter 11 on Lists of lists
 +
* Chapter 12 in Zelle, on Objects and Inheritance
 
|}
 
|}
  
Line 450: Line 556:
 
::{| class="mw-collapsible " style="width:100%" border="1"
 
::{| class="mw-collapsible " style="width:100%" border="1"
 
|- style="background:#dddddd;"
 
|- style="background:#dddddd;"
|width="60%"| '''Topics''':  
+
|width="60%"| '''Topics''': Polymorphism, Dictionaries, and Recursion
 
|width="15%"| '''Lab/Hw'''
 
|width="15%"| '''Lab/Hw'''
 
|width="25%"| '''Reading'''  
 
|width="25%"| '''Reading'''  
 
|-valign="top"
 
|-valign="top"
 
|
 
|
* '''Monday/Wednesday/Friday'''
+
[[File:WarppingPaper11.png|150px|right|link=http://www.science.smith.edu/dftwiki/index.php/Nice_Wrapping_Paper...]]
 +
* '''Monday'''
 +
::* [[Nice_Wrapping_Paper... | Wrapping paper...]]
 +
::* Polymorphism
 +
::* Dictionaries
 +
::* Recursion
 +
* '''Wednesday'''
 +
::* Dictionaries (cont'd)
 +
::* Recursion
 +
* '''Friday'''
 +
::* More recursion!
 +
::* A look at how recursion uses memory
 +
::* Back to minions and processing lists of bananas
 +
::* [[CSC111 Programs Created in Class 2018| Programs created in class]]
 +
::* [[media:CSC111_2018_Week12.pdf | slides]]
 
|
 
|
*  
+
* [[CSC111_Lab_12_2018 | Lab 12]]
 +
* [[CSC111_Homework_11_2018 | Homework 11]]
 
|
 
|
 
* Zelle, Section 11.6 on Dictionaries.
 
* Zelle, Section 11.6 on Dictionaries.
 +
* Zelle, Chapter 13 on Recursion
 
|}
 
|}
  
Line 476: Line 598:
 
::{| class="mw-collapsible" style="width:100%" border="1"
 
::{| class="mw-collapsible" style="width:100%" border="1"
 
|- style="background:#dddddd;"
 
|- style="background:#dddddd;"
|width="60%"| '''Topics''': Lists of lists, Inheritance
+
|width="60%"| '''Topics''': Advanced Topics: recursion
 
|width="15%"| '''Lab/Hw'''
 
|width="15%"| '''Lab/Hw'''
 
|width="25%"| '''Reading'''  
 
|width="25%"| '''Reading'''  
Line 482: Line 604:
 
|
 
|
 
* '''Monday'''
 
* '''Monday'''
* '''Wednesday''': <font color="magenta">Final Take-Home Exam</font>
+
[[File:maze.png|right|150px]]
 +
::* Visiting a maze
 +
::* Fractal trees
 +
::* [[CSC111_Programs_Created_in_Class_2018 | Programs created in class]]
 +
* '''Wednesday''': <font color="magenta">Final 1-week take-home exam</font>
 +
::* Towers of Hanoi
 +
::* [[CSC111_Programs_Created_in_Class_2018 | Programs created in class]]
 +
::* [[CSC111_Final_Exam_2018|Final Exam]]
 +
::* [[media:CSC111_2018_Week13.pdf | slides]]
 
|
 
|
*
+
* <font color="magenta">No labs this week</font>
 +
* [[CSC111_Final_Exam_2018|Final Exam]]
 
|
 
|
* Chapter 11 on Lists of lists
+
* Chapter 13 on Recursion
* Chapter 12 in Zelle, on Objects and Inheritance
 
 
|}
 
|}
  

Latest revision as of 08:10, 3 May 2018

D. Thiebaut (talk) 12:58, 16 January 2018 (EST)



Main Page | Syllabus | Weekly Schedule | Links & Resources |Piazza | TA Hours





Final Exam



 


Week 0 Jan 26    


Topics: Overview of CSC111 Lab/Hw Reading
  • Friday
  • No homework assignment this week



 


Week 1 Jan 29    


Topics: Introduction, Python, Idle, Piazza, Moodle submission Lab/Hw Reading
  • Monday
  • Wednesday
  • Friday
  • The programming process
  • Variables and literals
  • Memory: what does it look like?
  • Overloaded operators
  • Using the shell for quick testing
  • Definite Loops (for ... in sequence: )
  • Python documentation
  • The range() function
  • slides




 


Week 2 Feb 5    


Topics: Chapter 2: variables, definite loops, input, the range function Lab/Hw Reading
  • Monday
  • Wednesday: Snow day!
CalvinSnowDay.gif
  • Friday
  • Read Chapter 2 in Zelle.




 


Week 3 Feb. 12    


Topics: Arithmetic operators, math functions, main(). Lab/Hw Reading
  • Monday
  • 4 minutes from Grier's video: When computers were human. Start at time=28m12s.



WomenCalculatingWWII.jpg
  • Operators: * / + - ** // % abs()
  • The type() function
  • Writing a cash-machine program
  • Formatting numbers (see Section 5.8.2 in Zelle), and example program
  • Wednesday
  • Friday
  • Logistics
  • Accumulating Results
  • What are bits?
  • Slides
  • Read Chapter 3 in Zelle.




 


Week 4 Feb. 19    


Topics: Strings, Lists, and Files Lab/Hw Reading
  • Monday
  • Strings, indexing
  • positive and negative indexes
  • lists, indexing lists
  • string sections
  • Concept of mutability and immutability
  • Wednesday
  • Friday
  • Read Chapter 5 in Zelle




 


Week 5 Feb 26    


Topics: Functions, Files. Lab/Hw Reading
  • DaveMinion.png
    Monday
  • Wednesday
  • Review.
  • A note about complex 1-liners versus multi-line statements: use whatever feels comfortable!
  • Functions returning values
  • Examples, and exercises
  • Friday
  • Chapter 6: Defining Functions




 


Week 6 March 5    


Topics: Lab/Hw Reading
  • Monday
  • "...{x:y}...".format( )
  • indexing in a list
  • how range() works
  • functions receiving parameters, & returning values
  • Wednesday: Midterm Exam, in class, timed, on Moodle, closed notes, closed books, closed Idle.
  • Friday
  • Lab 6
  • No new homework. Homework 5 due after the break.
  • No new reading assignment this week.



Spring Break



 


Week 7 March 19    


Topics: Processing Files, Graphics, If Statements Lab/Hw Reading
  • Monday
  • Back to reading files
  • Writing text files
  • Graphics
  • If statements. Relational operators
  • Wednesday
  • More graphics, with points, rectangles, circles, text
  • Basics of animation
  • Testing for conditions: the IF statement
  • Friday
  • Graphics are covered in Chapter 4
  • If statements are covered in Chapter 7 in Zelle




 


Week 8 March 26    


Topics: If-Statements, Eliza Lab/Hw Reading
  • Monday
  • Boolean Operators (Chapter 8, Section 4)
  • Organization of Graphic Program
  • Dealing with Obstacles
  • Wednesday
  • Eliza
  • Indefinite loops: while loops
  • Friday
  • Indefinite Loops (Chapter 8)
  • Review for-loops
  • Nested for-loops
  • Break & Continue
  • Indefinite Loops and boolean operators are covered in Chapter 8.




 


Week 9 Apr. 2    


Topics: Exceptions, Classes, and Objects Lab/Hw Reading
  • Monday
  • Exceptions
  • Programming with Objects and Classes
  • Wednesday
  • Continue with classes
  • Min/Max of tuples
  • Die class
  • Cat class
  • Global vs local
  • Friday
  • Section 7.4 in Zelle, on Exceptions
  • Chapter 10: Defining Classes




 


Week 10 April 9    


Topics: Image Processing Lab/Hw Reading
CatGlasses.gif
FlowersSmith.gif
CatHat.gif
  • Monday
  • Image Processing
  • Nested for-loops for image processing
  • Displaying gif images
  • Sweep through an image: vertical sweep, horizontal sweep
  • Changing the color of a pixel
  • Changing the color of all the pixels of an image
  • Grey scales
  • Saturation
  • Wednesday
Piece.gif
Piece2.gif
  • More Image transformations
  • Copy an image
  • Mirror an image
  • Displaying a chessboard
  • Setting up a game of checkers
  • Friday
  • Continue with the game of checkers
  • Using objects made of 2 circles
  • Using a gif image for a piece
  • Moving checkers on the board
  • Removing checkers from the board
  • Adding a Quit button to the game
  • Lists of Lists (Chapter 11)
  • Sorting
  • Reversing
  • Removing duplicates
  • Chapter 11, Designing with Lists and Classes




 


Week 11 Apr 16    


Topics: Class inheritance Lab/Hw Reading
  • Monday
  • Wednesday
  • Class Inheritance
  • Example 1: Super class = GenericCar, derived classes = Taxi, CarWithTop
  • Example 2: Super class = Rectangle, derived class = RectLabel
  • Programs created in class
  • slides
  • Friday
JoeOrourkeQuantumComputing111.png
  • Guest lecture by Prof. Joseph O'Rourke on Quantum Computing
  • Chapter 11 on Lists of lists
  • Chapter 12 in Zelle, on Objects and Inheritance




 


Week 12 Apr 23    


Topics: Polymorphism, Dictionaries, and Recursion Lab/Hw Reading
WarppingPaper11.png
  • Monday
  • Wednesday
  • Dictionaries (cont'd)
  • Recursion
  • Friday
  • Zelle, Section 11.6 on Dictionaries.
  • Zelle, Chapter 13 on Recursion




 


Week 13 Apr 30    


Topics: Advanced Topics: recursion Lab/Hw Reading
  • Monday
Maze.png
  • Wednesday: Final 1-week take-home exam
  • Chapter 13 on Recursion











Links and Resources


Graphics


  • Zelle's graphic library can be found here
  • A page with color names supported by the graphics library.


On-Line Python books


  • disocovermagazine.com blog. Check out the answers posted by many readers. They contain some interesting links that you may find useful!


Python keywords


The list of all the reserved words of the Python language
and del for is raise assert elif from lambda return break else global not try class except if or while continue exec import pass yield def finally in print.


Python Programs in Textbook


  • All the programs of Zelle's Python textbook


Misc


  • When you work in pairs during the labs, or on homework assignments, you need to follow the protocol for 'pair programming' as discussed in this article.

Fun Programming Ideas to Explore on Your Own


TED: In 2007, Paul Rothemund gave TED a short summary of his specialty, DNA folding. Now he lays out in clear, abundant detail the immense promise of this field -- to create tiny machines that assemble themselves.