CS 240 – Lecture 11 Pseudocode.

Slides:



Advertisements
Similar presentations
compilers and interpreters
Advertisements

Chapter 2- Visual Basic Schneider1 Chapter 2 Problem Solving.
 Introduction to Programming History of programming.
Program Design and Development
Pseudocode and Algorithms
Slides prepared by Rose Williams, Binghamton University Chapter 3 Flow of Control Loops in Java.
Computer Science 1620 Programming & Problem Solving.
PRE-PROGRAMMING PHASE
Adapted from slides by Marie desJardins
Simple Program Design Third Edition A Step-by-Step Approach
Algorithmic Problem Solving CMSC 201 Adapted from slides by Marie desJardins (Spring 2015 Prof Chang version)
TMF1013 : Introduction To Computing Lecture 1 : Fundamental of Computer ComputerFoudamentals.
School of Computer Science & Information Technology G6DICP - Lecture 9 Software Development Techniques.
S2008Final_part1.ppt CS11 Introduction to Programming Final Exam Part 1 S A computer is a mechanical or electrical device which stores, retrieves,
Programming for Beginners Martin Nelson Elizabeth FitzGerald Lecture 5: Software Design & Testing; Revision Session.
What does a computer program look like: a general overview.
Problem Solving Techniques. Compiler n Is a computer program whose purpose is to take a description of a desired program coded in a programming language.
Dale Roberts 1 Program Control - Algorithms Department of Computer and Information Science, School of Science, IUPUI CSCI N305.
How Are Computers Programmed? CPS120: Introduction to Computer Science Lecture 5.
8.1 8 Algorithms Foundations of Computer Science  Cengage Learning.
Algorithms and Pseudocode
ALGORITHMS AND FLOWCHARTS. Why Algorithm is needed? 2 Computer Program ? Set of instructions to perform some specific task Is Program itself a Software.
Introduction to Computing Systems and Programming Programming.
Intro. to Computer Programming Eng. Nehal A. Mohamed Spring Semester-2016.
Algorithms and Pseudocode CS Principles Lesson Developed for CS4 Alabama Project Jim Morse.
Component 1.6.
Introduction to Computing Science and Programming I
Programming Languages
Component 1.6.
2008/09/22: Lecture 6 CMSC 104, Section 0101 John Y. Park
Chapter 2: Input, Processing, and Output
Algorithms, Part 2 of 3 Topics Problem Solving Examples Pseudocode
ALGORITHMS AND FLOWCHARTS
Programming Mehdi Bukhari.
The Pseudocode Programming Process
The Selection Structure
Algorithms, Part 2 of 3 Topics Problem Solving Examples Pseudocode
UMBC CMSC 104 – Section 01, Fall 2016
Lesson 9: "if-else-if" and Conditional Logic
Algorithm and Ambiguity
2008/09/24: Lecture 6b CMSC 104, Section 0101 John Y. Park
Strings, Line-by-line I/O, Functions, Call-by-Reference, Call-by-Value
Unit# 9: Computer Program Development
Bases and Representations, Memory, Pointers, Arrays, For-Loops
Topics Introduction to File Input and Output
Lesson 2 Programming constructs – Algorithms – Scratch – Variables Intro.
Algorithms & Pseudocode
2008/09/22: Lecture 5 CMSC 104, Section 0101 John Y. Park
Structured Program
Algorithms, Part 2 of 3 Topics Problem Solving Examples Pseudocode
Algorithms, Part 2 of 3 Topics Problem Solving Examples Pseudocode
Coding Concepts (Basics)
3 Control Statements:.
Algorithms, Part 2 of 3 Topics Problem Solving Examples Pseudocode
Algorithms, Part 2 of 3 Topics Problem Solving Examples Pseudocode
CSC128 FUNDAMENTALS OF COMPUTER PROBLEM SOLVING
Programming.
Algorithm and Ambiguity
Understanding Problems and how to Solve them by using Computers
Flowcharts and Pseudo Code
Algorithms, Part 2 of 3 Topics Problem Solving Examples Pseudocode
IPC144 Introduction to Programming Using C Week 4 – Lesson 1
Chapter 2: Input, Processing, and Output
Basic Concepts of Algorithm
Algorithms, Part 2 of 3 Topics Problem Solving Examples Pseudocode
Algorithms, Part 2 of 3 Topics Problem Solving Examples Pseudocode
Topics Introduction to File Input and Output
Lecture 18 Compilers and Language Translation (S&G, ch. 9)
1.3.7 High- and low-level languages and their translators
Software Development Techniques
Presentation transcript:

CS 240 – Lecture 11 Pseudocode

Pseudocode – Ideas on Paper before Coding This is going to be review of what should hopefully have been discussed in previous course work. Pseudocode is a structured in-English description of an algorithm. The lines of pseudocode act as instructions that should be good enough for a person familiar with the problem domain to follow and solve the problem. These instructions should be high-level but not ambiguous. You don't need to go into the mechanics of how a simple task should be accomplished. Example: Read a line from input. vs. Call fgets on buffer, 100, and stdin.

Pseudocode – Basic Instruction Sequences Pseudocode is intended to be a code, but it's not intended to be compiled for a computer. This means that it otherwise is intended to share the same structure as actual program code. At the very least, pseudocode consists of a sequence of instructions. Here's an example of pseudocode for a general morning: Wake up Shower Get dressed Eat breakfast

Pseudocode – Referring to Variables When writing out instructions, it's very likely that you will encounter variables, things you'll need to reference that were involved with other instructions. There are two ways to refer to them: indirectly and directly. Directly: Pick up a ball, call it ball1 Throw ball1 into the basket Indirectly: Pick up a ball Throw that ball into the basket You should only really use direct reference if something has already been named or not naming it would lead to ambiguity.

Pseudocode – Control Flow Like any algorithm, even one written in English needs control flow. There are states that need to be accounted for when solving a problem, so there must be things like If- and While-statements. For when these are needed, they naturally flow into the way you describe solving the problem. while my room is still dirty look for something to clean clean it You can also use if in the same natural way: if I find dirty clothes put them in the hamper then go back to cleaning

Pseudocode – Control Flow with For By now, you should be realizing that a lot of the keywords that we use in our programming languages come directly from their meaning in English. The for-loop is no different and we can use a similar statement in Pseudocode for every pair of pants in the hamper check if they have a big hole in them if they do throw them out

Pseudocode – Formal Treatment For academia and industry, when pseudocode is expected, there are some general expectations about clarity and consistency. There is no "standard" syntax for pseudocode but there's a general "I know it when I see it" for good and bad pseudocode. It's often good to establish conventions that you and your group are going to use so that there is no confusion about anything you've written. Common conventions include Using indentation to indicate block structure (as seen on previous slides) Starting control-flow lines with familiar terms like while, for, if, etc. Explicitly naming and assigning direct variables with words like "set X to ___"

Pseudocode – From Code to Code The secondary purpose for Pseudocode is to be turned into program code. Generally, Pseudocode is written for a programmer or by a programmer for structuring the idea behind an algorithm. When it's time to actually automate solving that problem, pseudocode should be translatable, line-by-line, to actual source code. Read a line from input fgets(str,10,stdin); Print that line to output printf("%s",str); Some lines of pseudocode may turn into more than one line of actual source code.

Pseudocode Examples – Homework 2 Echo Read one character from input If reading from input failed Print an error message Otherwise or else Print that character to output End program optional but sometimes it looks good

Pseudocode Examples – Homework 2 Count Read a character from input Set counter to 0 Set current to that character While that character wasn't End of File If that character is the same as current increment the counter Else print the counter set current to that character set counter to 1 Read a new character from input End Program

Pseudocode Examples – Homework 3 Mid For pseudocode for functions, it's fine to include a generic function header. function mid(first, second, third) if first is greater than second and third and second is greater than third return second otherwise return third if second is greater than first and third and first is greater than third return first if third is greater than first and second and first is greater than second return first otherwise return second End function It's obvious from the way the function is described that it has a return type and that it should be some numeric.

Pseudocode Examples – Homework 3 Snag function contains(line, ch) for every character in line if that character equals ch Return true Return false End function Main Read in a character as ch Clear the newline after that character For every line of input if line contains ch it's clear how to check! print "FOUND: " then print the line after that else print "NOT FOUND: " End program

Pseudocode Examples – Homework 4 Direct Direct1 Read a line from input Print that line to output Direct2 For every line in input Print that line to output

Pseudocode Examples – Homework 4 Sum Open the file "sum.txt" for reading Set sum to 0 Read a number from sum.txt this can be done with fscanf Add that number to sum Repeat until sum.txt runs out of numbers Open the file "result.txt" for writing Print sum to result.txt End program

Pseudocode Exercises – Groceries Shopping You're given a list of things that you need to buy at the grocery store. The objective of the algorithm is get everything on your list and go to the cashier to pay for it. Common concepts available to you: For any one item on the list, it's clear where it is in the store Between any two points in the store, you know how to get from one to the other. You have access to a shopping cart which can hold more than you need. You cannot carry everything in just your hands, but it may be tempting to try.

Topics for Next Week's Exam Program Execution Questions You'll be expected to look at C code and determine the state of the machine. Variable values Input read Output written Amount of memory allocated You'll be tested on your understanding of Numeric Representations Converting from Hex to Binary One's and Two's complements Comparing Numeric values of two different bases You'll be expected to know how lexical scoping works with functions.

Topics for Next Week's Exam You should be familiar with writing Pseudocode. You should have a base understanding of gdb. Any of the following may be tested: Compiling a program for debugging. Attaching the debugger. Setting breakpoints. Running the program. Stepping during the program. Finding Errors in C programs. Logical and Syntactic. Most importantly, you should be very familiar with basic C syntax, definitions, and semantics.

Topics for Next Week's Exam The last part of the program will be a Program on Paper. You will be given a program to write from scratch. It should have proper C syntax and should be as compiler-ready as if you had typed it in an editor. You will be expected to use your understanding of Pseudocode design the algorithm before you start writing the function. Partial credit will be awarded based on the quality of the Pseudocode and correctness of the program.