Introduction to Computer Science

Slides:



Advertisements
Similar presentations
Python Programming, 2/e1 Python Programming: An Introduction to Computer Science Chapter 2.
Advertisements

Adapted from John Zelle’s Book Slides
Python Programming: An Introduction to Computer Science
CSC 110 Writing simple programs [Reading: chapter 2] CSC 110 C 1.
Vahé Karamian Python Programming CS-110 CHAPTER 2 Writing Simple Programs.
Chapter 2 Writing Simple Programs
Chapter 1 Program Design
CS190/295 Programming in Python for Life Sciences: Lecture 1 Instructor: Xiaohui Xie University of California, Irvine.
Computer Science 101 Introduction to Programming.
Python Programming, 2/e1 Python Programming: An Introduction to Computer Science Chapter 1 Computers and Programs.
Adapted from John Zelle’s Book Slides1 CS177 Python Programming Chapter 1 Computers and Programs.
Announcements Project 2 Available Tomorrow (we will send mail) Will be due 11:59PM October 9 th (Sunday) Week 6 ( I will be traveling this week) Review.
Introduction to Python
Python Programming, 2/e1 Python Programming: An Introduction to Computer Science Chapter 2.
Python Programming, 2/e1 Python Programming: An Introduction to Computer Science Chapter 1 Computers and Programs.
CS 127 Writing Simple Programs.  Stages involved  Analyze the problem  Understand as much as possible what is trying to be solved  Determine Specifications.
Computer Science 101 Introduction to Programming.
Computer Science 101 Introduction to Programming.
CSC 110 Using Python [Reading: chapter 1] CSC 110 B 1.
Introduction to Python Dr. José M. Reyes Álamo. 2 Three Rules of Programming Rule 1: Think before you program Rule 2: A program is a human-readable set.
2. WRITING SIMPLE PROGRAMS Rocky K. C. Chang September 10, 2015 (Adapted from John Zelle’s slides)
Xiaojuan Cai Computational Thinking 1 Lecture 2 Simple Programs Xiaojuan Cai (蔡小娟) Fall, 2015.
1. COMPUTERS AND PROGRAMS Rocky K. C. Chang September 6, 2015 (Adapted from John Zelle’s slides)
Python Programming, 2/e1 Python Programming: An Introduction to Computer Science Chapter 2.
Python Programming, 3/e1 Python Programming: An Introduction to Computer Science Chapter 1 Computers and Programs.
Python Programming Module 1 Computers and Programs Python Programming, 2/e1.
And now for something completely different…
Chapter 2 Writing Simple Programs
Control Structures I Chapter 3
Introducing Python Introduction to Python.
Introduction to Computing Science and Programming I
Topics Designing a Program Input, Processing, and Output
CS1022 Computer Programming & Principles
Python: Experiencing IDLE, writing simple programs
Input and Output Upsorn Praphamontripong CS 1110
Chapter 4 C Program Control Part I
Introduction to Python
Topics Introduction to Repetition Structures
Python Programming: An Introduction to Computer Science
Python: Control Structures
Python Programming: An Introduction to Computer Science
The Selection Structure
Algorithms, Part 2 of 3 Topics Problem Solving Examples Pseudocode
Algorithm and Ambiguity
CS190/295 Programming in Python for Life Sciences: Lecture 1
First Python Program Professor Hugh C. Lauer CS-1004 — Introduction to Programming for Non-Majors (Slides include materials from Python Programming: An.
4. sequence data type Rocky K. C. Chang 16 September 2018
CS190/295 Programming in Python for Life Sciences: Lecture 2
3. Decision Structures Rocky K. C. Chang 19 September 2018
Introduction to Programming
Rocky K. C. Chang September 18, 2018 (Based on Zelle and Dierbach)
Algorithm and Ambiguity
5. Functions Rocky K. C. Chang 30 October 2018
Topics Introduction to Value-returning Functions: Generating Random Numbers Writing Your Own Value-Returning Functions The math Module Storing Functions.
15-110: Principles of Computing
CHAPTER 4 Iterative Structure.
Topics Designing a Program Input, Processing, and Output
Topics Designing a Program Input, Processing, and Output
12th Computer Science – Unit 5
Basic Concepts of Algorithm
Chopin’s Nocturne.
Introduction to Computer Science
The Last of the Mohicans (大地英豪)
Topic: Loops Loops Idea While Loop Introduction to ranges For Loop
Introduction to Programming
Introduction to Computer Science
Introduction to Computer Science
PYTHON - VARIABLES AND OPERATORS
Presentation transcript:

Introduction to Computer Science Instructor: Dr. Quincy Wu (solomon@ncnu.edu.tw) Textbook: John M. Zelle, "Python Programming: An Introduction to Computer Science", Franklin Beedle & Associates Inc.; 3rd Edition (Aug 2016). ISBN: 978-1-59028-2-755. Evaluation: Quiz (0%) Exercise & Homework (60%) Midterm Exam (20%) Final Exam (20%) Python Programming, 2/e

Spend 3 + 6 Hours in a Week Before a class Three-hour class Reading - textbook, online articles Before-class exercise Three-hour class After a class Homework You are encouraged to raise questions. Homework: Tetris, 2048 Late submission of in-class exercise: before 17:00 - 90%, before Wed 23:00 - 80%. Python Programming, 2/e Python Programming, 2/e

A Few Suggestions Take notes Think about it. Practice Practice again. Teach it. Identify your weakness and try to improve. Python Programming, 2/e

Program Power Software (programs) rule the hardware (the physical machine). The process of creating this software is called programming. Why learn to program? Fundamental part of computer science Having an understanding of programming helps you have an understanding of the strengths and limitations of computers. Python Programming, 2/e

Program Power Helps you become a more intelligent user of computers Instruct computers to handle repetitive routing tasks Helps the development of problem solving skills, especially in analyzing complex systems by reducing them to interactions between simpler systems. Devide-and-Conquer Prune-and-Search Programmers are in great demand! A lucrative career option Python Programming, 2/e

Programming Languages Natural language has ambiguity and imprecision problems when used to describe complex algorithms. I saw the man in the park with the telescope. Programs expressed in an unambiguous , precise way using programming languages. Every structure in programming language has a precise form, called its syntax Every structure in programming language has a precise meaning, called its semantics. Python Programming, 2/e

Programming Languages Programming language is like a code for writing the instructions the computer will follow. Programmers will often refer to their program as computer code. Process of writing an algorithm in a programming language often called coding. code規範 Python Programming, 2/e

Your Wording Must Be Precise Expecto Patronum! Python Programming, 2/e

Recipe:乳酪蛋黃酥 紫山藥去皮切厚片。 放入蒸籠蒸約30分鐘,取出碾壓成泥,加入糖、奶油揉勻,並視紫山藥含水量適量添加糯米粉,加至不黏手為原則。 紫山藥平分15g為一小糰,並用水沾濕手將山藥球搓成圓型(可沾上芝麻)。 熱油鍋至150℃,慢慢放入步驟的山藥球,炸至表面呈金黃色即可撈起瀝乾油脂。 Python Programming, 2/e

Exercise Start “IDLE (Python)” Try to type a simple code Integrated Development Environment Try to type a simple code File - New Run - Run Module You may need to save the source code. Python Programming, 2/e

Python Programming: An Introduction to Computer Science Chapter 2 Writing Simple Programs Python Programming, 2/e

Objectives To be able to understand and write Python statements to output information to the screen, assign values to variables, get numeric information entered from the keyboard, and perform a counted loop Python Programming, 2/e

Software Development Process Python Programming, 2/e

Example Program: Temperature Converter Analysis – the temperature is given in Celsius, user wants it expressed in degrees Fahrenheit. Specification Input : temperature in Celsius Output : temperature in Fahrenheit Output = 9/5*(Input) + 32 Python Programming, 2/e

Example Program: Temperature Converter Design - Input, Process, Output (IPO) Prompt the user for input (Celsius temperature) Process it to convert it to Fahrenheit using F = 9/5(C) + 32 Output the result by displaying it on the screen Python Programming, 2/e

Example Program: Temperature Converter Before we start coding, let’s write a rough draft of the program in pseudocode Pseudocode is precise English that describes what a program does, step by step. Using pseudocode, we can concentrate on the algorithm rather than the programming language. Python Programming, 2/e

Example Program: Temperature Converter Pseudocode: Input the temperature in degrees Celsius (call it celsius) Calculate fahrenheit as (9/5)*celsius+32 Output fahrenheit Now we need to convert this to Python! Python Programming, 2/e

Example Program: Temperature Converter #convert.py # A program to convert Celsius temps to Fahrenheit # by: Susan Computewell celsius = eval(input("What is the Celsius temperature? ")) fahrenheit = (9/5) * celsius + 32 print("The temperature is ",fahrenheit," degrees Fahrenheit.") Python Programming, 2/e Python Programming, 1/e

Example Program: Temperature Converter Once we write a program, we should test it! ============ RESTART: M:/Waste/convert2.py ============ What is the Celsius temperature? 100 The temperature is 212.0 degrees Fahrenheit. >>> What is the Celsius temperature? 27 The temperature is 80.6 degrees Fahrenheit. What is the Celsius temperature? 0 The temperature is 32.0 degrees Fahrenheit. Python Programming, 2/e

Elements of Programs Names Names are given to variables (celsius, fahrenheit), modules (main, convert), etc. These names are called identifiers Every identifier must begin with a letter or underscore (“_”), followed by any sequence of letters, digits, or underscores. Identifiers are case sensitive. Python Programming, 2/e

Elements of Programs These are all different, valid names X Celsius Spam spam spAm Spam_and_Eggs Spam_And_Eggs Python Programming, 2/e

Elements of Programs Some identifiers are part of Python itself. These identifiers are known as reserved words. This means they are not available for you to use as a name for a variable, etc. in your program. and, del, for, is, raise, assert, elif, in, print, etc. For a complete list, see Table 2.1 (P.32) Python Programming, 2/e

Elements of Programs Expressions The fragments of code that produce or calculate new data values are called expressions. Literals are used to represent a specific value, e.g. 3.9, 1, 1.0 Simple identifiers can also be expressions. Python Programming, 2/e

Elements of Programs >>> x = 5 >>> x 5 >>> print(x) >>> print(spam) Traceback (most recent call last): File "<pyshell#15>", line 1, in -toplevel- print spam NameError: name 'spam' is not defined >>> NameError is the error when you try to use a variable without a value assigned to it. Python Programming, 2/e

Elements of Programs Simpler expressions can be combined using operators. +, -, *, /, **, // Spaces are irrelevant within an expression. The normal mathematical precedence applies. ((x1 – x2) / 2*n) + (spam / k**3) Python Programming, 2/e

Elements of Programs Output Statements A print statement can print any number of expressions. By default, a single blank space character is placed between the displayed values. Successive print statements will display on separate lines. A bare print() will print a blank line. Python Programming, 2/e

Elements of Programs print(3+4) print(3, 4, 3+4) print() print(3, 4, end=" ") print(3 + 4) print("The answer is", 3+4) print(3,4,3+4, sep=':') 7 3 4 7 The answer is 7 3:4:7 Python Programming, 2/e

Assignment Statements Simple Assignment <variable> = <expr> variable is an identifier, expr is an expression The expression on the RHS is evaluated to produce a value which is then associated with the variable named on the LHS. Python Programming, 2/e

Assignment Statements x = 3.9 * x * (1-x) fahrenheit = 9/5 * celsius + 32 x = 5 Python Programming, 2/e

Assignment Statements Variables can be reassigned as many times as you want! >>> myVar = 0 >>> myVar >>> myVar = 7 7 >>> myVar = myVar + 1 8 >>> Python Programming, 2/e

Assignment Statements Variables are like a box we can put values in. When a variable changes, the old value is erased and a new one is written in. Python Programming, 2/e

Assigning Input The purpose of an input statement is to get input from the user and store it into a variable. <variable> = eval(input(<prompt>)) Python Programming, 2/e

Assigning Input First the prompt is printed The input part waits for the user to enter a value and press <Enter> The expression that was entered is evaluated to turn it from a string of characters into a Python value (a number). The value is assigned to the variable. Python Programming, 2/e

Try It Out! a = eval(input("a = ? ")) b = eval(input("b = ? ")) c = a + b print(a, "+", b, "=", c) a = ? 10 b = ? 20 10 + 20 = 30 a = input("a = ? ") b = input("b = ? ") c = a + b print(a, "+", b, "=", c) a = ? 10 b = ? 20 10 + 20 = 1020 Python Programming, 2/e

Exercise: In which year were you born? Python Programming, 2/e

Simultaneous Assignment Several values can be calculated at the same time <var>, <var>, … = <expr>, <expr>, … Evaluate the expressions in the RHS and assign them to the variables on the LHS Python Programming, 2/e

Simultaneous Assignment sum, diff = x+y, x-y How could you use this to swap the values for x and y? Why doesn’t this work? x = y y = x We could use a temporary variable… Before: x = 3 y = 5 After: x = 5 y = 5 temp = x x = y y = temp Python Programming, 2/e

Simultaneous Assignment We can swap the values of two variables quite easily in Python! x, y = y, x >>> x = 3 >>> y = 4 >>> print(x, y) 3 4 >>> x, y = y, x 4 3 Python Programming, 2/e

Simultaneous Assignment We can use this same idea to input multiple variables from a single input statement! Use commas to separate the inputs def spamneggs(): spam, eggs = eval(input("Enter # of slices of spam followed by # of eggs: ")) print ("You ordered", eggs, "eggs and", spam, "slices of spam. Yum!“) >>> spamneggs() Enter the number of slices of spam followed by the number of eggs: 3, 2 You ordered 2 eggs and 3 slices of spam. Yum! >>> Python Programming, 2/e

Definite Loops A definite loop executes a definite number of times, i.e., at the time Python starts the loop it knows exactly how many iterations to do. The beginning and end of the body are indicated by indentation. for <var> in <sequence>: <body> definite integration Python Programming, 2/e Python Programming, 1/e

Definite Loops for <var> in <sequence>: <body> The variable after the for is called the loop index. It takes on each successive value in sequence. Python Programming, 2/e

Definite Loops >>> for i in [0,1,2,3]: print (i) 1 2 3 1 2 3 >>> for odd in [1, 3, 5, 7]: print(odd*odd) 9 25 49 >>> Python Programming, 2/e

Definite Loops In chaos.py, what did range(10) do? >>> list(range(10)) [0, 1, 2, 3, 4, 5, 6, 7, 8, 9] range is a built-in Python function that generates a sequence of numbers, starting with 0. list is a built-in Python function that turns the sequence into an explicit list The body of the loop executes 10 times. See Chapter 5 for more details about sequences and lists. Python Programming, 2/e Python Programming, 1/e

Definite Loops for loops alter the flow of program execution, so they are referred to as control structures. Python Programming, 2/e

Example Program: Future Value Analysis Money deposited in a bank account earns interest. How much will the account be worth 10 years from now? Inputs: principal, interest rate Output: value of the investment in 10 years Python Programming, 2/e

Example Program: Future Value Specification User enters the initial amount to invest, the principal User enters an annual percentage rate, the interest The specifications can be represented like this … Python Programming, 2/e

Example Program: Future Value Inputs principal The amount of money being invested, in dollars apr The annual percentage rate expressed as a decimal number. Output The value of the investment 10 years in the future Relatonship Value after one year is given by principal * (1 + apr). This needs to be done 10 times. Python Programming, 2/e

Example Program: Future Value Design Print an introduction Input the amount of the principal (principal) Input the annual percentage rate (apr) Repeat 10 times: principal = principal * (1 + apr) Output the value of principal Python Programming, 2/e

Example Program: Future Value Implementation Each line translates to one line of Python (in this case) Print an introduction print ("This program calculates the future") print ("value of a 10-year investment.") Input the amount of the principal principal = eval(input("Enter the initial principal: ")) Python Programming, 2/e

Example Program: Future Value Input the annual percentage rate apr = eval(input("Enter the annual interest rate: ")) Repeat 10 times: for i in range(10): Calculate principal = principal * (1 + apr) principal = principal * (1 + apr) Output the value of the principal at the end of 10 years print ("The value in 10 years is:", principal) Python Programming, 2/e

Example Program: Future Value # futval.py # A program to compute the value of an investment # carried 10 years into the future def main(): print("This program calculates the future value of a 10-year investment.") principal = eval(input("Enter the initial principal: ")) apr = eval(input("Enter the annual interest rate: ")) for i in range(10): principal = principal * (1 + apr) print ("The value in 10 years is:", principal) main() Python Programming, 2/e

Example Program: Future Value >>> main() This program calculates the future value of a 10-year investment. Enter the initial principal: 100 Enter the annual interest rate: .03 The value in 10 years is: 134.391637934 Enter the annual interest rate: .10 The value in 10 years is: 259.37424601 Python Programming, 2/e

Exercise: Stars Python Programming, 2/e