Presentation is loading. Please wait.

Presentation is loading. Please wait.

CONTROL STRUCTURES: SEQUENTIAL, SELECTIVE, AND REPETITIVE

Similar presentations


Presentation on theme: "CONTROL STRUCTURES: SEQUENTIAL, SELECTIVE, AND REPETITIVE"— Presentation transcript:

1 CONTROL STRUCTURES: SEQUENTIAL, SELECTIVE, AND REPETITIVE

2 THREE CATEGORIES OF CONTROL STRUCTURES:
SEQUENTIAL SELECTIVE REPETITIVE

3 SEQUENTIAL CONTROL FLOWS FROM STATEMENT_1 TO STATEMENT_2 AND SO ON TO STATEMENT_N.

4 statement_1 statement_2 statement_n
. statement_n

5 SELECTIVE CONTROL FOLLOWS ONE OF SEVERAL ALTERNATIVES OF LOGIC FLOW BASED ON A CONDITION.

6 ENTER true logical expression false process process EXIT

7 REPETITIVE CONTROL ALLOWS FOR THE REPETITION OF A CERTAIN TASK BASED ON A CONDITION.

8 ENTER true logical expression process false EXIT

9 EXAMPLE: PROBLEM: DESIGN, DEVELOP AND IMPLEMENT A PAYROLL SYSTEM THAT COMPUTES AN EMPLOYEE'S GROSS PAY. THE SYSTEM SHOULD ALSO COMPUTE NET PAY USING THE FOLLOWING CRITERION TO DETERMINE THE AMOUNT TO BE DEDUCTED FROM THE EMPLOYEE'S GROSS SALARY FOR SOCIAL SECURITY TAX: IF AN EMPLOYEE EARNS MORE THAN $ IN A WEEK, DEDUCT A TAX OF $25.00; OTHERWISE, DEDUCT NO TAX. PROCESSING SHOULD BE REPEATED, BASED ON THE USER’S REQUEST.

10 ANALYSIS AND SPECIFICATIONS:
1. DISCUSSION TO COMPUTE GROSS PAY (THE PROBLEM’S OUTPUT), WE MUST KNOW THE HOURS WORKED AND THE HOURLY RATE (THE PROBLEM’S INPUT). AFTER READING THESE DATA, WE CAN COMPUTE GROSS PAY BY FINDING THEIR PRODUCT. NEXT WE CAN COMPUTE THE EMPLOYEE'S NET PAY (THE PROBLEM’S OTHER OUTPUT) BY SUBTRACTING ANY TAX DEDUCTION FROM THE GROSS PAY.

11 2. DATA REQUIREMENTS a) INPUT hours (float) // HOURS WORKED rate (float) // HOURLY RATE final (int) // NUMBER OF REPETITIONS b) OUTPUT gross (float) // GROSS PAY net (float) // NET PAY c) INTERMEDIATE DATA counter (int) // LOOP CONTROL VARIABLE d) NAMED CONSTANTS tax_bracket = // MAXIMUM SALARY WITHOUT // A TAX DEDUCTION tax = // AMOUNT OF TAX WITHHELD

12 3. RELEVANT FORMULAE gross pay = hourly rate x hours worked net pay = gross pay - deductions

13 DESIGN: 1. STRUCTURE CHART PAYROLL SYSTEM LEVEL 0 LEVEL 1 DISPLAY
INSTRUCTIONS GET DATA COMPUTE GROSS PAY COMPUTE NET PAY DISPLAY RESULTS

14 MODULE SPECIFICATIONS FOR THE GROSS PAY ARE: GROSS PAY
(WE INCLUDE ONLY ONE MODULE DESCRIPTION AS AN EXAMPLE): AS AN ALTERNATIVE METHOD TO FURTHER AID IN UNDERSTANDING HOW DATA ARE TRANSMITTED, WE WILL INCLUDE MODULE SPECIFICATIONS FOR "GROSS PAY" MODULE. MODULE SPECIFICATIONS FOR THE GROSS PAY ARE: GROSS PAY DATA RECEIVED: hours, rate INFORMATION RETURNED: gross LOGIC: THE HOURS ARE MULTIPLIED BY THE PAY RATE TO PRODUCE THE GROSS PAY.

15 3. ALGORITHM: 1. DISPLAY USER INSTRUCTIONS 2. WHILE COUNTER <= FINAL 2.1. GET DATA 2.2. COMPUTE GROSS PAY 2.3. COMPUTE NET PAY IF GROSS PAY > TAXBRACKET THEN DEDUCT TAX ELSE DEDUCT NO TAX 2.4. DISPLAY RESULTS

16 NEW CONCEPTS LOGICAL EXPRESSIONS, SELECTION, AND REPETITION

17 CONDITIONS ARE WRITTEN IN THE FORM OF LOGICAL EXPRESSIONS.
THERE ARE TWO POSSIBLE VALUES FOR SUCH AN EXPRESSION: 1 (REPRESENTS TRUE), OR 0 (REPRESENTS FALSE).

18 LOGICAL EXPRESSIONS MAY BE FORMED BY USING COMBINATIONS OF TWO KINDS OF OPERATORS: RELATIONAL AND LOGICAL.

19 RELATIONAL OPERATORS == EQUAL TO != NOT EQUAL TO
OPERATOR MEANING == EQUAL TO != NOT EQUAL TO < LESS THAN <= LESS THAN OR EQUAL TO > GREATER THAN >= GREATER THAN OR EQUAL TO

20 LOGICAL OPERATORS OPERATOR MEANING && AND || OR ! NOT

21 LOGICAL EXPRESSIONS ARE MADE UP OF VARIABLES, CONSTANTS AND OPERATORS.
operand operator operand

22 EXAMPLES: (counter <= FINAL) (class_average < 70.0)
total_grade >= class_average hours_worked <= 35.0 divisor == 0 (angle1 + angle2 + angle3) != 180

23 (midterm_grade >= 90) && (final_grade >= 90)
(side_1 == side_2) || (side_2 == side_3) ! (class_average >= 70.0)

24 && TRUTH TABLE operand operator operand outcome
1(true) && 1(true) 1(true) 1(true) && 0(false) 0(false) 0(false) && 1(true) 0(false) 0(false) && 0(false) 0(false)

25 || TRUTH TABLE operand operator operand outcome
1(true) || 1(true) 1(true) 1(true) || 0(false) 1(true) 0(false) || 1(true) 1(true) 0(false) || 0(false) 0(false)

26 ! TRUTH TABLE operator operand outcome ! 1(true) 0(false)
! 0(false) 1(true)

27 PRECEDENCE OF OPERATORS (REVISITED)
! * / % + - < <= >= > == != && || = HIGHEST PRECEDENCE LOWEST PRECEDENCE EXPRESSION EVALUATION IS LEFT TO RIGHT.

28 THE if STATEMENT if STATEMENT INSTRUCTIONS ARE EXECUTED IN A LOGICAL ORDER THAT DIFFERS FROM THEIR PHYSICAL ORDER. A CONDITION IS EVALUATED, AND AN ACTION IS TAKEN DEPENDING ON THE TRUTH VALUE OF THE CONDITION (THE ANSWER CAN BE EITHER 1 (TRUE) OR 0 (FALSE).

29 ONE ALTERNATIVE if (logical_expression) statement_1;
if (total_grade >= class_average) cout << "passing!" << endl;

30 LOGIC FLOW OF if WITH ONE ALTERNATIVE
ENTER true logical expression false statement_1 EXIT

31 TWO ALTERNATIVES if (logical expression) statement_1a; else
statement_1b; if (total_grade >= class_average) cout << "passing!" << endl; else cout << "in trouble!!!" << endl;

32 LOGIC FLOW OF if WITH TWO ALTERNATIVES
ENTER true logical expression false statement_1a statement_1b EXIT

33 COMPOUND STATEMENTS AND THE if
THE “TASK” TO BE CARRIED OUT WITHIN THE if STATEMENT MAY BE SIMPLE OR COMPOUND. ASSIGNMENT STATEMENTS, FUNCTION CALLS, INPUT/OUTPUT STATEMENTS, OTHER if STATEMENTS, ETC. MAY ALSO BE INCLUDED IN ANY OF THE if ALTERNATIVES.

34 EXAMPLE: if (total_grade >= class_average) {
passing_grade = passing_grade + 1; cout << "passing!" << endl; } else weak_grade = weak_grade + 1; cout << "in trouble!!!" << endl;

35 MULTIPLE ALTERNATIVES
if (logical expression_1) statement_1; else if (logical expression_2) statement_2; . else if (logical expression_n) statement_n; else statement_n+1;

36 if (total_grade >= 90)
letter_grade = ‘A’; else if (total_grade >= 80) letter_grade = ‘B’; else if (total_grade >= 70) letter_grade = ‘C’; else if (total_grade >= 60) letter_grade = ‘D’; else letter_grade = ‘F’;

37 LOGIC FLOW OF if WITH MULTIPLE ALTERNATIVES
ENTER true logical expression_1 false true logical expression_2 false statement_2a statement_1 statement_2b EXIT

38 LOGIC FLOW OF if WITH MULTIPLE ALTERNATIVES
ENTER true logical expression_1 false true logical expression_2 false statement_1a statement_1b statement_2 EXIT

39 SEQUENTIAL if VERSUS NESTED if STATEMENTS
if (number > 0) positive_num = positive_num + 1; if (number < 0) negative_num = negative_num + 1; if (number == 0) zero_num = zero_num + 1;

40 if (total_grade >= 90)
letter_grade = ‘A’; else if (total_grade >= 80) letter_grade = ‘B’; else if (total_grade >= 70) letter_grade = ‘C’; else if (total_grade >= 60) letter_grade = ‘D’; else letter_grade = ‘F’;

41 COMPOUND if STATEMENTS
. if (side_1 == side_2) && (side_2 == side_3) cout << "Triangle is Equilateral" << endl; else if (side_1 == side_2) || (side_2 == side_3) || (side_1 == side_3) cout << "Triangle is Isosceles" << endl; else cout << "Triangle is Scalene" << endl;

42 THE REPETITION OF TASKS IN A PROGRAM IS CALLED LOOPING.
THE while STATEMENT THE REPETITION OF TASKS IN A PROGRAM IS CALLED LOOPING. WITH THE while LOOP, IF A CONDITION EXISTS, TASK IS EXECUTED. AFTER THE EXECUTION OF THE TASK, THE CONDITION IS TESTED AGAIN. THIS CONTINUES AS LONG AS THE CONDITION REMAINS TRUE.

43 while (logical_expression)
statement; total = 0; counter = 1; // the following is a loop while (counter <= 10) { cout << "Enter grade: "; cin >> grade; total = total + grade; counter = counter + 1; }

44 WHAT IF THE LOGICAL EXPRESSION IS FALSE TO BEGIN WITH?
TASK NEVER EXECUTES, AND FLOW OF CONTROL CONTINUES WITH THE FIRST STATEMENT FOLLOWING THE LOOP.

45 IMPLEMENTATION: // FILE: Payroll.cpp
// Computes and prints gross pay and net pay given an // hourly rate and number of hours worked. Deducts a tax // of $25 if gross salary exceeds $100; otherwise, deducts // no tax. #include <iostream.h> // needed for cin and cout void main() { // FUNCTIONS USED: // Display user instructions void Instruct_user (const float, // IN: max salary for no deductions const float); // IN: tax amount // Find the gross salary float Compute_gross (float, // IN: number of hours worked float); // IN: hourly payrate

46 // Find the net salary float Compute_net (float, // IN: gross salary const float, // IN: max salary for no deductions const float); // IN: tax amount // LOCAL DATA: const float tax_bracket = ; // max salary for // no deductions const float tax = 25.00; // tax amount float hours; // input: hours worked float rate; // input: hourly payrate int final; // input: number of repetitions float gross; // output: gross pay float net; // output: net pay int counter; // intermediate: loop control variable

47 // Display user instructions
Instruct_user (tax_bracket, tax); // Enter number of repetitions cout << "Number of repetitions : ”; cin >> final; counter = 1; while (counter <= final) { // Enter hours and rate cout << "Hours worked: "; cin >> hours; cout << "Hourly rate: "; cin >> rate; // Compute gross salary gross = Compute_gross (hours, rate);

48 // Compute net salary net = Compute_net (gross, tax_bracket, tax); // Print gross and net cout << "Gross salary is $" << gross << endl; cout << "Net salary is $" << net << endl; // Increment the counter counter ++; } // end of the while loop return; } // end of main ()

49 // Display user instructions
void Instruct_user (const float tax_bracket, // IN: maximum salary // for no deduction const float tax) // IN: tax amount { cout << "This program computes gross and net salary." << endl; cout << "A tax amount of $" << tax << " is deducted for" cout << "an employee who earns more than $" << tax_bracket << endl << endl; cout << "First, enter how many times do you want to " << "repeat the calculations." << endl << endl; cout << "Then, enter hours worked and hourly rate" << endl; cout << "on separate lines after the prompts." << endl; cout << "Press <RETURN> after typing each number." return; } // end of Instruct_user

50 // Find the gross salary
float Compute_gross (float hours, // IN: number of hours worked float rate) // IN: hourly payrate { // Compute gross pay return hours * rate; } // end of Compute_gross // Find the net salary float Compute_net (float gross, // IN: gross salary const float tax_bracket, // IN: max salary // for no deductions const float tax) // IN: tax amount // Compute net salary if (gross > tax_bracket) return gross - tax; // deduct a tax amount else return gross; // deduct no tax } // end of Compute_net


Download ppt "CONTROL STRUCTURES: SEQUENTIAL, SELECTIVE, AND REPETITIVE"

Similar presentations


Ads by Google