CompSci 001 6.1 Today’s topics Problem Solving Pseudocode Notes from Zachary Dodds’ CS 5 course at Harvey Mudd Upcoming ä More Python Reading Brookshear,

Slides:



Advertisements
Similar presentations
1 CS101 Introduction to Computing Lecture 17 Algorithms II.
Advertisements

CS 100: Roadmap to Computing Fall 2014 Lecture 0.
Efficiency of Algorithms
Lists Introduction to Computing Science and Programming I.
Bellevue University CIS 205: Introduction to Programming Using C++ Lecture 3: Primitive Data Types.
Efficiency of Algorithms
Introduction to Computers and Programming Lecture 4: Mathematical Operators New York University.
Connecting with Computer Science, 2e
Chapter 2: Algorithm Discovery and Design
Please pick up an attendance question and submit in 5 minutes CS 1003 Lecture #3 Sept 12, 2006 Knarig Arabshian.
The UNIVERSITY of NORTH CAROLINA at CHAPEL HILL Adrian Ilie COMP 14 Introduction to Programming Adrian Ilie June 27, 2005.
Introduction to a Programming Environment
JavaScript, Third Edition
Introduction to C Programming
Chapter 2: Algorithm Discovery and Design
Chapter 2: Algorithm Discovery and Design
Cmpt-225 Simulation. Application: Simulation Simulation  A technique for modeling the behavior of both natural and human-made systems  Goal Generate.
Adapted from slides by Marie desJardins
What is RobotC?!?! Team 2425 Hydra. Overview What is RobotC What is RobotC used for What you need to program a robot How a robot program works Framework.
Computer Science 1000 Spreadsheets II Permission to redistribute these slides is strictly prohibited without permission.
CompSci Today’s topics Networks and the Internet Problem Solving Pseudocode Upcoming ä Programming language syntax ä Python Reading Brookshear,
Introduction to Python
Algorithmic Problem Solving CMSC 201 Adapted from slides by Marie desJardins (Spring 2015 Prof Chang version)
Chapter 2: Algorithm Discovery and Design Invitation to Computer Science, C++ Version, Third Edition.
Chapter 3.  Traditionally, programming languages have assigned different types of data for different types of numbers.  In many languages, there may.
Now String theory To Do: Lists This stuff hurts my brane. when you learn string theory from google images… Goal: Thinking like a machine You should now.
CompSci Today’s topics Designing and Implementing Algorithms Problem solving Pseudocode Java Syntax and Grammars Upcoming More Java Acknowledgements.
Input, Output, and Processing
Extending the Definition of Exponents © Math As A Second Language All Rights Reserved next #10 Taking the Fear out of Math 2 -8.
The Algorithmic Model. What is Computer Science What is Programming Algorithms –Definition –Properties of Good Algorithms –Describing Algorithms –Examples.
Chapter 13 Recursion. Learning Objectives Recursive void Functions – Tracing recursive calls – Infinite recursion, overflows Recursive Functions that.
Collecting Things Together - Lists 1. We’ve seen that Python can store things in memory and retrieve, using names. Sometime we want to store a bunch of.
Introduction to Algorithms. What is Computer Science? Computer Science is the study of computers (??) This leaves aside the theoretical work in CS, which.
Major objective of this course is: Design and analysis of modern algorithms Different variants Accuracy Efficiency Comparing efficiencies Motivation thinking.
EECS 110: Lec 3: Data Aleksandar Kuzmanovic Northwestern University
Built-in Data Structures in Python An Introduction.
Copyright © 2012 Pearson Education, Inc. Publishing as Pearson Addison-Wesley C H A P T E R 2 Input, Processing, and Output.
Lecture 2: Introduction to C Programming. OBJECTIVES In this lecture you will learn:  To use simple input and output statements.  The fundamental data.
EECS 110: Lec 4: Functions and Recursion Aleksandar Kuzmanovic Northwestern University
CPS Topics l Networks revisited l Java intro l Decision Trees l Problem solving and computing with numbers l Upcoming ä Numeric computation Course.
CompSci Today’s topics Parsing Java Programming Notes from Tammy Bailey Reading Great Ideas, Chapter 3 & 4.
VISUAL C++ PROGRAMMING: CONCEPTS AND PROJECTS Chapter 2A Reading, Processing and Displaying Data (Concepts)
EECS 110: Lec 3: Data Aleksandar Kuzmanovic Northwestern University
CHAPTER 2 PROBLEM SOLVING USING C++ 1 C++ Programming PEG200/Saidatul Rahah.
EECS 110: Lec 9: Review for the Midterm Exam Aleksandar Kuzmanovic Northwestern University
Searching CSE 103 Lecture 20 Wednesday, October 16, 2002 prepared by Doug Hogan.
Uncertainty2 Types of Uncertainties Random Uncertainties: result from the randomness of measuring instruments. They can be dealt with by making repeated.
EECS 110: Lec 3: Data Aleksandar Kuzmanovic Northwestern University
Chapter 2: Algorithm Discovery and Design Invitation to Computer Science.
Expressions Version Topics Arithmetic expressions Conversions Operator precedence String class 2.
CPS Today’s topics l Algorithms and pseudocode l Notes adapted from Marti Hearst at UC Berkeley and David Smith at Georgia Tech Upcoming ä Beginning.
Chapter 15 Running Time Analysis. Topics Orders of Magnitude and Big-Oh Notation Running Time Analysis of Algorithms –Counting Statements –Evaluating.
CS0007: Introduction to Computer Programming Primitive Data Types and Arithmetic Operations.
CS 115 Lecture 5 Math library; building a project Taken from notes by Dr. Neil Moore.
Lecture 3: More Java Basics Michael Hsu CSULA. Recall From Lecture Two  Write a basic program in Java  The process of writing, compiling, and running.
Advanced Algorithms Analysis and Design
EECS 110: Lec 9: Review for the Midterm Exam
Aleksandar Kuzmanovic Northwestern University
Variables, Expressions, and IO
Fermi Questions Enrico Fermi.
Objective of This Course
Data types Numeric types Sequence types float int bool list str
Algorithm Discovery and Design
CS 100: Roadmap to Computing
EECS 110: Lec 4: Functions and Recursion
Algorithms vs. Programming
CS 100: Roadmap to Computing
Algorithms vs. Programming
Introduction to Computer Science
Presentation transcript:

CompSci Today’s topics Problem Solving Pseudocode Notes from Zachary Dodds’ CS 5 course at Harvey Mudd Upcoming ä More Python Reading Brookshear, Chapter 5

CompSci Problem Solving Programming is a strenuous exercise in problem solving G. Polya. How to Solve It, 2 nd ed., Princeton University Press, l Understand the problem ä What are its parts? unknown, data, condition ä Does the problem make sense? Is it feasible? ä Think about the problem, get a sense of what it needs l Make a plan ä Find the connection between givens and result ä What kind of problem is it? Is it familiar? ä Think about generalizations, specializations, variants l Carry out the plan ä Check each step l Examine the result ä Does it make sense?

CompSci Are problem solving skills primarily domain-specific? You’re first told: A fortress surrounded by a moat is connected to land by numerous narrow bridges. An attacking army successfully captures the fortress by sending only a few soldiers across each bridge, converging upon it simultaneously. l Then you’re asked: A patient has a cancerous tumor. Beams of radiation will destroy the tumor, but in high doses will also destroy healthy tissue surrounding the tumor. How can you use radiation to safely eradicate the tumor? Do the skills transfer between subjects? Is a good math problem solver a good computer science problem solver? How about English to Physics?

CompSci Programming and Problem Solving l Latin school movement in the 1600s ä Teach proper habits of the mind ä Thorndike’s classic “transfer of training” studies found that learning Latin did not produce strong transfer to other domains l Programming teaches problem solving movement of late 1900s ä Seymour Papert, 1980, In learning to program, “powerful intellectual skills are learned in the process  The activity of programming computers is fundamentally an exercise in problem solving. The program represents the solution to some problem and the execution behavior of that program becomes a means to judge, unemotionally, the success of the problem solution. ä Programming is a strenuous exercise in problem solving post hoc, ergo propter hoc.

CompSci Back of the envelope calculations Jon Bentley. Programming Pearls. 2 nd edition. A-W, l Engineering technique to approximate and check answers ä Two answers are better than one ä Quick checks ä Rules of thumb ä Practice l Ad claims that salesperson drove 100,000 miles in a year. True? l Newspaper article states that a United States quarter dollar coin has “an average life of 30 years.” How can you check that claim?

CompSci Why “back of the envelope” estimates? l Often need to make rapid estimates ä to eliminate candidate solutions ä establish feasibility ä sketch out potential trade-offs l Most remember key numbers related to their field, not every detail l Hence we need to estimate ä which numbers are important ä values of numbers needed ä how to perform the calculation l Emphasis is on “order of magnitude” estimates ä to nearest factor of 10 (or 2)

CompSci Orders of Magnitude l How far away is home? Is it more like 1, or 10, or 100 miles? ä Probably do not know exactly ä Is it approximately "a couple", or "a few", or "a lot” ä Estimate based on powers rather than multiples of 10 l How tall is your dorm? More like 1, 10, 100, 1000 feet? ä 1 foot tall is like a doll house, so that’s out ä What do we know that is about 10 feet big? Hmm... People ä If building is a couple of people high, 10 sounds good. ä But that means 1000, would be 100 people high, so that’s out ä So 10 or 100 depending on how many people tall the building is l Use orders of magnitude as brackets to find reasonable range

CompSci Example: How many piano tuners in NYC l Approximately how many people are in New York City? ä 10,000,000 l Does every individual own a piano? ä No l Reasonable to assert “individuals do not own pianos; families do”? ä Yes l About how many families are there in a city of 10 million people? ä Perhaps there are 2,000,000 families l Does every family own a piano? ä No l Perhaps one out of every five does ä That would mean there are about 400,000 pianos in NYC

CompSci Example: Piano Tuners continued l How many piano tuners are needed for 400,000 pianos? ä Some people never get around to tuning their piano ä Some people tune their piano every month ä Assume "on the average" every piano gets tuned once a year, then there are 400,000 every year l How many piano tunings can one piano tuner do? ä Assume that average piano tuner can tune four pianos a day ä Assume that there are 200 working days per year ä That means every tuner can tune about 800 pianos per year l How many piano tuners are needed in NYC? ä Number of tuners is approximately 400,000/800 or 500

CompSci Example: Piano Tuners summary l “Back of the Envelope” estimates have ä Formulas: provide roadmap to upcoming calculations ä Estimates: brief justification of approximations in formula ä Calculations: estimates and known facts are use in formula l Piano Tuner example ä Formula: # tuners = # pianos x # repairs / # repairs per day x # days ä Estimates # pianos ~= 400,000 (20% of 2,000,000 families own pianos) # repairs ~= 1 per piano (some many, some none) # repairs per day ~= 4 #working days ~= 200 (5 x 50 – vacation, sickness) ä Calculation # tuners ~= (400,000 x 1) / (4 x 200) = 500

CompSci Estimation General Principles l Recall Einstein's famous advice ä Everything should be made as simple as possible, but no simpler l Do not worry about constant factors of 2, π, etc. ä Round to “easy” number or nearest order of magnitude l Guess numbers you do not know ä Within bounds of common sense (accuracy increases with experience) l Adjust geometry, etc., to suit you ä Assume a cow is spherical if it helps l Extrapolate from what you do know ä Use ratios to assume unknown value is similar to known quantity l Apply a ‘plausibility’ filter ä If answer seems unbelievable, it probably is ä Can usually set range of reasonable values that indicates major mistake (e.g., speed cannot be faster than light!)

CompSci What’s wrong with this algorithm? (From back of shampoo bottle) Directions: Wet Hair Apply a small amount of shampoo Lather Rinse Repeat

CompSci Properties of good algorithms l Good algorithms must be ä Correct ä Complete ä Precise ä Unambiguous l And should be ä Efficient ä Simple ä Contain levels of abstraction

CompSci Algorithms l Hand-waving not allowed! l Specifying algorithms requires you to say what is really involved in making it work. l Example: ä How does a computer work? ä Hand-wave: zeros & ones ä Real answer: see later part of class. l You learn to know when you don’t know ä “I know nothing except the fact of my ignorance.” ä Socrates, from Diogenes Laertius, Lives of Eminent Philosophers

CompSci Describing Algorithms Pictures Natural language (English) Pseudo-code Specific high-level programming language More easily expressed More precise

CompSci Pseudocode l A shorthand for specifying algorithms l Leaves out the implementation details l Leaves in the essence of the algorithm l What does this algorithm do? l How many times does it print Hello? <

CompSci Sequential search

CompSci Picking courses 1.Make a list of courses you want to register for, in order of priority 2.Start with empty schedule. Number of courses = 0. 3.Choose highest priority class on list. 4.If the chosen class is not full and its class time does not conflict with classes already scheduled, then register for the class (2 steps): 1.Add the class to the schedule 2.Increment the number of classes scheduled 5.Cross that class off of your list. 6.Repeat steps 3 through 5 until the number of classes scheduled is >= 4, or until all classes have been crossed out. 7.Stop.

CompSci Flowcharts End Begin Make list of classes you want to take Num Classes = 0 Choose highest priority class on list Add the class to your schedule. Increment Num Classes. Cross the class off your list. yes no Is this class full? Is there a time conflict? Num Classes >= 4? More classes on list? yes no

CompSci Programming Primitive Operations l Assign a value to a variable l Call a method l Arithmetic operation l Comparing two numbers l Indexing into an array l Following an object reference l Returning from a method

CompSci Components of Computing Algorithms Any computing algorithm will have AT MOST five kinds of components: Data structures to hold data Instructions change data values Conditional expressions to make decisions Control structures to act on decisions Modules to make the algorithm manageable by abstraction, i.e., grouping related components

CompSci Game l 10 coins ä You and a friend have a stack of 10 coins ä On each person’s turn, they remove either 1 or 2 coins from the stack ä The person who removes the last coin wins. ä Can you win? l 10 coins with a twist ä 10 coins, can now ALSO place 1 or 2 coins back on the stack ä Person who removes last coin wins ä Should you go first or second, and what’s your strategy

CompSci Can all information be represented using lists ? Networks Images/Video Sounds/Speech { 2, 3, 5, 7, 11 } Data and lists? ‘Many years later, as he faced the firing squad, Colonel Aureliano Buendia was to remember that distant afternoon when his father took him to discover ice.’ Text Sets Ideas?

CompSci Inside the machine… x = 41 y = x + 1 name: x type: int LOC: What is happening behind the scenes: What's happening in python: "variables as containers" memory location 300 id, del ComputationData Storage name: y type: int LOC: memory location 304

CompSci Python Data Types bool int long float ** True False Numeric NameExampleWhat is it? values with a fractional part integers > integers <= the results from a comparison: ==, !=,, = "Boolean value"

CompSci Datatypes as genes… bool Dominant int long float Recessive 41 + True 10** ** / 5 1 / 5 What will these results be?

CompSci Python Operators Precedence * % ** / > < == + - Caution Level = Highest Lowest ** *%/><==+- = - ( ) remainder power is equal to set equal to divide as usual

CompSci % 3 % the "mod" operator 8 % 3 9 % 3 16 % 7 x%4 == 0 x%2 == 0 For what values of x are these True ? What happens on these years? x%y returns the remainder when x is divided by y x%2 == 1

CompSci Computer Memory Random Access Memory (RAM) byte = 8 bits word = 4 bytes = 32 bits is a long list of memory locations bit = 1 "bucket" of charge name: x type: int LOC: bytes for an int on or off is it really a coincidence that this looks like the string theory picture?? 42

CompSci str ing functions str len + * converts input to a string returns the string’s length str(42) returns '42' len('42') returns 2 'XL' + 'II' returns 'XLII' 'VI'*7 returns 'VIVIVIVIVIVIVI' concatenates strings repeats strings s1 = "ha" s2 = "t" Given these strings s1 + s2 2*s1 + s2 + 2*(s1+s2) What are

CompSci String surgery s[ ] indexes into the string, returning a one-character string s = ’duke university baby' s[0] returns ’d' s[6] returns s[ ] returns 'e' Which index returns 'e'? python != English s[len(s)] returns Read "s-of-zero" or "s-zero" index 19

CompSci More on strings l Negative indices count from the back l s[-1] returns ‘y' s[-11] returns s[-0] returns s[ : ] slices the string, returning a substring s[ : : ] skip-slices, returning a subsequence the third index is the "stride" length it defaults to 1

CompSci Lists ~ Strings of anything L = [ 3.14, [2,40], 'third', 42 ] Square brackets tell python you want a list. len(L) L[0] L[0:1] 'hi' How could you extract from L Slicing: always returns the same type Indexing: could return a different type Commas separate elements.

CompSci Raising and razing lists What are "Quiz" pi = [3,1,4,1,5,9]Q = [ 'pi', "isn't", [4,2] ] What slice of pi is [3,4,5] What is pi[pi[2]] ? message = 'You need parentheses for chemistry !' What is message[::5] What are pi[0] * (pi[1] + pi[2]) and pi[0] * (pi[1:2] + pi[2:3]) What is message[9:15] What are What slice of pi is [3,1,4] How many nested pi 's before pi[…pi[0]…] produces an error? Name(s): Extra! Mind Muddlers Part 2Part 1 Q[0] Q[0:1] Q[0][1] Q[1][0] len(pi) len(Q) len(Q[1])

CompSci Functioning in Python Some basic, built-in functions: abs max min sum range round bool float int long list str these change data from one type to another absolute value of lists creates lists only as accurately as it can! help dir These are the most important:

CompSci Functioning in Python Far more are available in separate files, or modules: import math math.sqrt( 1764 ) dir(math) from math import * pi sin( pi/2 ) accesses math.py 's functions lists all of math.py 's functions same, but without typing math. all of the time… help() help modules

CompSci # my own function! def dbl( x ): """ returns double its input, x """ return 2*x Functioning in Python

CompSci # my own function! def dbl( x ): """ returns double its input, x """ return 2*x Functioning in Python Comments Docstrings (1)describes overall what the function does, and (2)explains what the inputs mean/are They become part of python's built-in help system! With each function be sure to include one that They begin with # keywords def starts the function return stops it immediately and sends back the return value Some of Python's baggage…

CompSci Functioning in Python >>> undo('caf') >>> undo(undo('caf')) # is it dis-0 or dis-O, anyway? def undo(s): """ this "undoes" its string input, s """ return 'de' + s strings, lists, numbers … all data are fair game

CompSci random thoughts import random random.choice( range(0,100) ) help dir These are the most important: