CSC 1051 – Data Structures and Algorithms I

Slides:



Advertisements
Similar presentations
CSC 1051 – Algorithms and Data Structures I
Advertisements

Primitive Data Types There are a number of common objects we encounter and are treated specially by almost any programming language These are called basic.
Data Types in Java Data is the information that a program has to work with. Data is of different types. The type of a piece of data tells Java what can.
Basic Syntax: Data & Expressions
ECE122 L2: Program Development February 1, 2007 ECE 122 Engineering Problem Solving with Java Lecture 2 Program Development.
Aalborg Media Lab 21-Jun-15 Software Design Lecture 2 “ Data and Expressions”
Program Elements We can now examine the core elements of programming (as implemented in Java) We focuse on: data types variable declaration and use, constants.
ECE122 L3: Expression Evaluation February 6, 2007 ECE 122 Engineering Problem Solving with Java Lecture 3 Expression Evaluation and Program Interaction.
1 Expressions, Operators Expressions Operators and Precedence Reading for this class: L&L, 2.4.
CSci 142 Data and Expressions. 2  Topics  Strings  Primitive data types  Using variables and constants  Expressions and operator precedence  Data.
1 Character Strings and Variables Character Strings Variables, Initialization, and Assignment Reading for this class: L&L,
String Escape Sequences
Expressions, Data Conversion, and Input
1 Variables, Constants, and Data Types Primitive Data Types Variables, Initialization, and Assignment Constants Characters Strings Reading for this class:
Outline Character Strings Variables and Assignment Primitive Data Types Expressions Data Conversion Interactive Programs Graphics Applets Drawing Shapes.
Chapter 2 Data and Expressions. © 2004 Pearson Addison-Wesley. All rights reserved2-2 Data and Expressions Let's explore some other fundamental programming.
CSC 1051 – Data Structures and Algorithms I Dr. Mary-Angela Papalaskari Department of Computing Sciences Villanova University Course website:
Outline Questions / Review Predefined Objects Variables Primitive Data Arithmetic Expressions Interactive Programs Decision Making Assignments.
CSC 1051 – Algorithms and Data Structures I Dr. Mary-Angela Papalaskari Department of Computing Sciences Villanova University Course website:
Program Statements Primitive Data Types and Strings.
Copyright © 2007 Pearson Education, Inc. Publishing as Pearson Addison-WesleyCopyright © 2011 Pearson Education, Inc. Publishing as Pearson Addison-Wesley.
CSC 1051 – Data Structures and Algorithms I Dr. Mary-Angela Papalaskari Department of Computing Sciences Villanova University Course website:
Assignment Statements Operator Precedence. ICS111-Java Programming Blanca Polo 2 Assignment, not Equals  An assignment statement changes the value of.
Copyright © 2009 Pearson Education, Inc. Publishing as Pearson Addison-Wesley Java Software Solutions Foundations of Program Design Sixth Edition by Lewis.
CSC 1051 – Algorithms and Data Structures I Dr. Mary-Angela Papalaskari Department of Computing Sciences Villanova University Course website:
© 2004 Pearson Addison-Wesley. All rights reserved ComS 207: Programming I Instructor: Alexander Stoytchev
Chapter 2 Data and Expressions Part One. © 2004 Pearson Addison-Wesley. All rights reserved2-2/29 Data and Expressions Let's explore some other fundamental.
Chapter 2 topics Concept # on Java Subset Required for AP Exam print and println10. Testing of output is restricted to System.out.print and System.out.println.
Chapter 2 Data and Expressions Java Software Solutions Foundations of Program Design 1.
Chapter 2: Data and Expressions String and String Concatenation Escape Sequences Variables Primitive Date Types Expressions Interactive Programs.
CSC 1051 M.A. Papalaskari, Villanova University Algorithms Dr. Mary-Angela Papalaskari Department of Computing Sciences Villanova University Course website:
Programming in Java (COP 2250) Lecture 4 Chengyong Yang Fall, 2005.
Operators and Expressions. 2 String Concatenation  The plus operator (+) is also used for arithmetic addition  The function that the + operator performs.
CSC 1051 – Algorithms and Data Structures I Dr. Mary-Angela Papalaskari Department of Computing Sciences Villanova University Course website:
Data and Expressions Let's explore some other fundamental programming concepts Chapter 2 focuses on: –character strings –primitive data –the declaration.
Instructor: Alexander Stoytchev CprE 185: Intro to Problem Solving (using C)
© 2007 Pearson Addison-Wesley. All rights reserved2-1 Character Strings A string of characters can be represented as a string literal by putting double.
1 Data and Expressions Chapter 2 In PowerPoint, click on the speaker icon then the “play” button to hear audio narration.
CSCI 1100/1202 January 14, Abstraction An abstraction hides (or ignores) the right details at the right time An object is abstract in that we don't.
CSCI 1100/1202 January 18, Arithmetic Expressions An expression is a combination of operators and operands Arithmetic expressions compute numeric.
Chapter 2: Data and Expressions. Variable Declaration In Java when you declare a variable, you must also declare the type of information it will hold.
Data and Expressions. Let's explore some other fundamental programming concepts Chapter 2 focuses on: Character Strings Primitive Data The Declaration.
© 2006 Pearson Education Chapter 2: Objects and Primitive Data Presentation slides for Java Software Solutions for AP* Computer Science A 2nd Edition by.
CSC 1051 – Data Structures and Algorithms I Dr. Mary-Angela Papalaskari Department of Computing Sciences Villanova University Course website:
© 2004 Pearson Addison-Wesley. All rights reserved August 27, 2007 Primitive Data Types ComS 207: Programming I (in Java) Iowa State University, FALL 2007.
Chapter 2 Data and Expressions
Primitive Data Types August 28, 2006 ComS 207: Programming I (in Java)
CSC 1051 – Data Structures and Algorithms I
Data Conversion & Scanner Class
Multiple variables can be created in one declaration
Chapter 2 Data and Expressions
Escape Sequences What if we wanted to print the quote character?
Data and Expressions Part One
Lecture 3 Expressions Richard Gesick.
Objects and Primitive Data
Chapter 2 Create a Chapter 2 Workspace Create a Project called Notes
Data Types and Expressions
Module 2 - Part 1 Variables, Assignment, and Data Types
CSC 1051 – Data Structures and Algorithms I
Chapter 2: Objects and Primitive Data
CSC 1051 – Data Structures and Algorithms I
Instructor: Alexander Stoytchev
Java Programming Presented by Dr. K. SATISH KUMAR,
Data Types and Expressions
Repetition CSC 1051 – Data Structures and Algorithms I Course website:
Data Types and Expressions
Presentation transcript:

CSC 1051 – Data Structures and Algorithms I Lecture 3: Variables and assignment CSC 1051 – Data Structures and Algorithms I Dr. Mary-Angela Papalaskari Department of Computing Sciences Villanova University Course website: www.csc.villanova.edu/~map/1051/ CSC 1051 M.A. Papalaskari, Villanova University

Last time – Lab 1: Learn about jGrasp - the programming environment that we will be using in this class Compile and run a java program Understand the relationship between a Java class name and the name of the .java file where the class is defined Practice using basic Java output statements and adding documentation (comments) to your source code. Learn about variables, string literals, concatenation. E.g., int x = 42, count = 100; "Many wise words" "Many " + " many wise words" "Many \"wise\" words" Explore Java syntax Experience some errors! CSC 1051 M.A. Papalaskari, Villanova University

Character Strings A string literal is represented by putting double quotes around the text Examples: "This is a string literal." "123 Main Street" "X" Every character string is an object in Java, defined by the String class CSC 1051 M.A. Papalaskari, Villanova University

System.out.println ("Whatever you are, be a good one."); The println Method In the Lincoln program we invoked the println method to print a character string The System.out object represents a destination (the monitor screen) to which we can send output System.out.println ("Whatever you are, be a good one."); method name object information provided to the method (parameters) CSC 1051 M.A. Papalaskari, Villanova University

The print Method The System.out object has another method: print is similar to the println except that it does not advance to the next line Example: Countdown.java CSC 1051 M.A. Papalaskari, Villanova University

//******************************************************************** // Countdown.java Author: Lewis/Loftus // // Demonstrates the difference between print and println. public class Countdown { //----------------------------------------------------------------- // Prints two lines of output representing a rocket countdown. public static void main (String[] args) System.out.print ("Three... "); System.out.print ("Two... "); System.out.print ("One... "); System.out.print ("Zero... "); System.out.println ("Liftoff!"); // appears on first output line System.out.println ("Houston, we have a problem."); } CSC 1051 M.A. Papalaskari, Villanova University

Output Three... Two... One... Zero... Liftoff! Houston, we have a problem. //******************************************************************** // Countdown.java Author: Lewis/Loftus // // Demonstrates the difference between print and println. public class Countdown { //----------------------------------------------------------------- // Prints two lines of output representing a rocket countdown. public static void main (String[] args) System.out.print ("Three... "); System.out.print ("Two... "); System.out.print ("One... "); System.out.print ("Zero... "); System.out.println ("Liftoff!"); // appears on first output line System.out.println ("Houston, we have a problem."); } CSC 1051 M.A. Papalaskari, Villanova University

String Concatenation The string concatenation operator (+) is used to append one string to the end of another "And one more " + "thing" It can also be used to append a number to a string A string literal cannot be broken across two lines in a program See Facts.java CSC 1051 M.A. Papalaskari, Villanova University

//******************************************************************** // Facts.java Author: Lewis/Loftus // // Demonstrates the use of the string concatenation operator and the // automatic conversion of an integer to a string. public class Facts { //----------------------------------------------------------------- // Prints various facts. public static void main (String[] args) // Strings can be concatenated into one long string System.out.println ("We present the following facts for your " + "extracurricular edification:"); System.out.println (); // A string can contain numeric digits System.out.println ("Letters in the Hawaiian alphabet: 12"); continue CSC 1051 M.A. Papalaskari, Villanova University

// A numeric value can be concatenated to a string continue // A numeric value can be concatenated to a string System.out.println ("Dialing code for Antarctica: " + 672); System.out.println ("Year in which Leonardo da Vinci invented " + "the parachute: " + 1515); System.out.println ("Speed of ketchup: " + 40 + " km per year"); } CSC 1051 M.A. Papalaskari, Villanova University

Output We present the following facts for your extracurricular edification: Letters in the Hawaiian alphabet: 12 Dialing code for Antarctica: 672 Year in which Leonardo da Vinci invented the parachute: 1515 Speed of ketchup: 40 km per year continue // A numeric value can be concatenated to a string System.out.println ("Dialing code for Antarctica: " + 672); System.out.println ("Year in which Leonardo da Vinci invented " + "the parachute: " + 1515); System.out.println ("Speed of ketchup: " + 40 + " km per year"); } CSC 1051 M.A. Papalaskari, Villanova University

Escape Sequences What if we wanted to print the quote character? Let’s try something like this… System.out.println ("I said "Hello" to you."); An escape sequence is a series of characters that represents a special character An escape sequence begins with a backslash character (\) System.out.println ("I said \"Hello\" to you."); CSC 1051 M.A. Papalaskari, Villanova University

Escape Sequences Some Java escape sequences: See Roses.java \b \t \n \r \" \' \\ Meaning backspace tab newline carriage return double quote single quote backslash See Roses.java CSC 1051 M.A. Papalaskari, Villanova University

//******************************************************************** // Roses.java Author: Lewis/Loftus // // Demonstrates the use of escape sequences. public class Roses { //----------------------------------------------------------------- // Prints a poem (of sorts) on multiple lines. public static void main (String[] args) System.out.println ("Roses are red,\n\tViolets are blue,\n" + "Sugar is sweet,\n\tBut I have \"commitment issues\",\n\t" + "So I'd rather just be friends\n\tAt this point in our " + "relationship."); } CSC 1051 M.A. Papalaskari, Villanova University

Output Roses are red, Violets are blue, Sugar is sweet, But I have "commitment issues", So I'd rather just be friends At this point in our relationship. //******************************************************************** // Roses.java Author: Lewis/Loftus // // Demonstrates the use of escape sequences. public class Roses { //----------------------------------------------------------------- // Prints a poem (of sorts) on multiple lines. public static void main (String[] args) System.out.println ("Roses are red,\n\tViolets are blue,\n" + "Sugar is sweet,\n\tBut I have \"commitment issues\",\n\t" + "So I'd rather just be friends\n\tAt this point in our " + "relationship."); } CSC 1051 M.A. Papalaskari, Villanova University

Quick Check Write a single println statement that produces the following output: "Thank you all for coming to my home tonight," he said mysteriously. CSC 1051 M.A. Papalaskari, Villanova University

Quick Check Write a single println statement that produces the following output: "Thank you all for coming to my home tonight," he said mysteriously. System.out.println ("\"Thank you all for " + "coming to my home\ntonight,\" he said " + "mysteriously."); CSC 1051 M.A. Papalaskari, Villanova University

Today: Problem Solving Create a program that will help us calculate a grade point average (GPA) given the number of quality points (QP) and the number of credits. The appropriate formula is GPA = QP / credits We assume A, B, C, D, F grading system. CSC 1051 M.A. Papalaskari, Villanova University

For Example GPA = 52 / 16 = 3.25 Course Credits Grade QPs Underwater Basket Weaving 3 A = 4 12 Main Line Boutiques B = 3 9 Winning the Hoops Lottery C = 2 6 Web Surfing Alg and Data Structures 4 16 Totals 52 GPA = 52 / 16 = 3.25 CSC 1051 M.A. Papalaskari, Villanova University

Topic Thread 2.1 Character Strings 2.2 Variables, Assignment 2.3 Data Types, in particular int, double 2.4 Expressions (simple) 2.5 Data Conversion 2.6 Interactive Programs 5.1 Boolean Expressions 5.2 The if Statement 5.4 The while Statement CSC 1051 M.A. Papalaskari, Villanova University

The GPA Problem Solution 1 //********************************************** // GPA01.java // // Prints out a QPA public class GPA01 { public static void main (String[ ] args) System.out.println ("Quality Points: 52"); System.out.println ("Credits: 16"); System.out.println (“\n\tGPA: 3.25"); } The GPA Problem Solution 1 Not very exciting, is it? Let’s add some storage (remember our model of computing) CSC 1051 M.A. Papalaskari, Villanova University

Multiple variables can be created in one declaration A variable is a name for a location in memory A variable must be declared by specifying the variable's name and the type of information that it will hold data type variable name int credits; int count, temp, result; Multiple variables can be created in one declaration CSC 1051 M.A. Papalaskari, Villanova University

Variable Initialization A variable can be given an initial value in the declaration int sum = 0; int base = 32, max = 149; When a variable is referenced in a program, its current value is used. CSC 1051 M.A. Papalaskari, Villanova University

Assignment Statement Changes the value of a variable The assignment operator is the = sign total = 55 - discount; The expression on the right is evaluated and the result is stored in the variable on the left The old value that was in total is overwritten See Geometry.java (page 68) CSC 1051 M.A. Papalaskari, Villanova University

Assignment operator Assignment ( = ) copies the value of the right side into the memory location associated with the left side It does not (for primitive types) set up an ongoing equivalence int davesAge = 21; int suesAge; suesAge = davesAge; davesAge = 22; System.out.println (davesAge); // prints 22 System.out.println (suesAge); // prints 21 Tracing program code is an important skill !! CSC 1051 M.A. Papalaskari, Villanova University

Primitive Data There are eight primitive data types in Java Four of them represent integers: byte, short, int, long Two of them represent floating point numbers: float, double One of them represents characters: char And one of them represents boolean values: boolean CSC 1051 M.A. Papalaskari, Villanova University

Numeric Primitive Data Type byte short int long float double Storage 8 bits 16 bits 32 bits 64 bits Min Value -128 -32,768 -2,147,483,648 < -9 x 1018 +/- 3.4 x 1038 with 7 significant digits +/- 1.7 x 10308 with 15 significant digits Max Value 127 32,767 2,147,483,647 > 9 x 1018 CSC 1051 M.A. Papalaskari, Villanova University

A variable is only declared once! A variable can be given an initial value in the declaration int sum = 0; declaration Later in the program the value of a variable can change: sum = 1; assignment CSC 1051 M.A. Papalaskari, Villanova University

Strings are not primitive data We can still declare and use String variables: declaration String message = “Roses are red”; … And use assignment to change their values: message = message + “\nViolets are blue”; assignment CSC 1051 M.A. Papalaskari, Villanova University

Solution 2 Still not very exciting, is it? Let’s add some processing //******************************************** // GPA02.java // // Prints out a GPA public class GPA02 { public static void main (String[ ] args) int qp = 52; int credits = 16; double gpa = 3.25; System.out.println ("Quality Points: " + qp); System.out.println ("Credits: " + credits); System.out.println (); System.out.println (“\tGPA: " + gpa); } Solution 2 Still not very exciting, is it? Let’s add some processing CSC 1051 M.A. Papalaskari, Villanova University

Expressions An expression is a combination of one or more operators and operands Arithmetic expressions compute numeric results and make use of the arithmetic operators: Addition Subtraction Multiplication Division Remainder + - * / % If either or both operands used by an arithmetic operator are floating point, then the result is a floating point CSC 1051 M.A. Papalaskari, Villanova University

Division and Remainder If both operands to the division operator (/) are integers, the result is an integer (the fractional part is discarded) 14 / 3 equals 4 8 / 12 equals The remainder operator (%) returns the remainder after dividing the second operand into the first 14 % 3 equals 2 8 % 12 equals 8 CSC 1051 M.A. Papalaskari, Villanova University

result = total + count / max - offset; Operator Precedence Operators can be combined into complex expressions result = total + count / max - offset; Operators have a well-defined precedence which determines the order in which they are evaluated Multiplication, division, and remainder are evaluated prior to addition, subtraction, and string concatenation Arithmetic operators with the same precedence are evaluated from left to right, but parentheses can be used to force the evaluation order CSC 1051 M.A. Papalaskari, Villanova University

Operator Precedence What is the order of evaluation in the following expressions? a + b + c + d + e a – b / c + d * e a / (b + c) - d % e a / (b * (c + (d - e))) CSC 1051 M.A. Papalaskari, Villanova University

Assignment Revisited The assignment operator has a lower precedence than the arithmetic operators First the expression on the right hand side of the = operator is evaluated answer = sum / 4 + MAX * lowest; 4 1 3 2 Then the result is stored in the variable on the left hand side CSC 1051 M.A. Papalaskari, Villanova University

Assignment Revisited The right and left hand sides of an assignment statement can contain the same variable First, one is added to the original value of count count = count + 1; Then the result is stored back into count (overwriting the original value) CSC 1051 M.A. Papalaskari, Villanova University

Increment and Decrement The increment and decrement operators use only one operand The increment operator (++) adds one to its operand The decrement operator (--) subtracts one from its operand The statement count++; is functionally equivalent to count = count + 1; CSC 1051 M.A. Papalaskari, Villanova University

Increment and Decrement The increment and decrement operators can be applied in postfix form: count++ or prefix form: ++count When used as part of a larger expression, the two forms can have different effects Because of their subtleties, the increment and decrement operators should be used with care CSC 1051 M.A. Papalaskari, Villanova University

Solution 3 A little more interesting but ... //******************************************** // GPA03.java // // Prints out a GPA public class GPA03 { public static void main (String[ ] args) int qp = 52; int credits = 16; double gpa = qp / credits; System.out.println ("Quality Points: " + qp); System.out.println ("Credits: " + credits); System.out.println (); System.out.println (“\tGPA: " + gpa); } Solution 3 A little more interesting but ... What happened to the output? CSC 1051 M.A. Papalaskari, Villanova University

Summary Print/println String concatenation Escape sequences Variables Data types Assignment operator Arithmetic operators Operator precedence CSC 1051 M.A. Papalaskari, Villanova University

Homework Review Sections 2.1-2.4 Do Exercises EX 2.6, 2.7, 2.8, 2.11 Always do all self-review exercises when you review material Do Exercises EX 2.6, 2.7, 2.8, 2.11 Read Sections 2.5, 2.6 to prepare for next class Some slides adapted from a presentation by Daniel Joyce and from the slides accompanying Java Software Solutions by Lewis & Loftus Caveman image is from http://www.toonpool.com/cartoons/PRIMITIVE%20CAVEMAN%20WORDS_25547# CSC 1051 M.A. Papalaskari, Villanova University