Fundamentals of Programmingce.sharif.edu/courses/90-91/2/ce153-1/resources... · Fundamentals of...

18
Fundamentals of Programming Lecture 3 Hamed Rasifard 1

Transcript of Fundamentals of Programmingce.sharif.edu/courses/90-91/2/ce153-1/resources... · Fundamentals of...

Page 1: Fundamentals of Programmingce.sharif.edu/courses/90-91/2/ce153-1/resources... · Fundamentals of Programming Lecture 3 Hamed Rasifard 1. Outline ... [3], and so on until it completes

Fundamentals of Programming

Lecture 3Hamed Rasifard

1

Page 2: Fundamentals of Programmingce.sharif.edu/courses/90-91/2/ce153-1/resources... · Fundamentals of Programming Lecture 3 Hamed Rasifard 1. Outline ... [3], and so on until it completes

Outline

• #define Preprocessor

• Sorting Arrays

• Bubble Sort

• Computing Mean, Median, and mode

2

Page 3: Fundamentals of Programmingce.sharif.edu/courses/90-91/2/ce153-1/resources... · Fundamentals of Programming Lecture 3 Hamed Rasifard 1. Outline ... [3], and so on until it completes

#define Preprocessor

• The #define directive defines an identifier and a character sequence (a set of characters) that will be substituted for the identifier each time it is encountered in the source file

• The identifier is referred to as a macro name and the replacement process as macro replacement

3

#define macro-name char sequence

Page 4: Fundamentals of Programmingce.sharif.edu/courses/90-91/2/ce153-1/resources... · Fundamentals of Programming Lecture 3 Hamed Rasifard 1. Outline ... [3], and so on until it completes

Sorting Arrays

• Sorting data (i.e., placing the data into a particular order such as ascending or descending) is one of the most important computing applications

• Arrays are one of the most important tools to keep data, hence, should be sorted

4

Page 5: Fundamentals of Programmingce.sharif.edu/courses/90-91/2/ce153-1/resources... · Fundamentals of Programming Lecture 3 Hamed Rasifard 1. Outline ... [3], and so on until it completes

The Bubble Sort

• The technique we use is called the bubble sort because the smaller values gradually “bubble” their way upward to the top of the array like air bubbles rising in water, while the larger values sink to the bottom of the array

• This technique also is called the sinking sort

5

Page 6: Fundamentals of Programmingce.sharif.edu/courses/90-91/2/ce153-1/resources... · Fundamentals of Programming Lecture 3 Hamed Rasifard 1. Outline ... [3], and so on until it completes

The Bubble Sort Code

6

#include <stdio.h>#define SIZE 10/* function main begins program execution */ int main( void ) { /* initialize a */ int a[ SIZE ] = { 2, 6, 4, 8, 10, 12, 89, 68, 45, 37 }; int pass; /* passes counter */ int i; /* comparisons counter */ int hold; /* temporary location used to swap array elements */ printf( "Data items in original order\n" ); /* output original array */ for ( i = 0; i < SIZE; i++ ) { printf( "%4d", a[ i ] ); } /* end for */

Page 7: Fundamentals of Programmingce.sharif.edu/courses/90-91/2/ce153-1/resources... · Fundamentals of Programming Lecture 3 Hamed Rasifard 1. Outline ... [3], and so on until it completes

The Bubble Sort Code(Cont.)

7

/* bubble sort */ /* loop to control number of passes */ for ( pass = 1; pass < SIZE; pass++ ) {

/* loop to control number of comparisons per pass */ for ( i = 0; i < SIZE - 1; i++ ) { /* compare adjacent elements and swap them if first element is greater than second element */ if ( a[ i ] > a[ i + 1 ] ) { hold = a[ i ]; a[ i ] = a[ i + 1 ]; a[ i + 1 ] = hold; } /* end if */ } /* end inner for */ } /* end outer for */

Page 8: Fundamentals of Programmingce.sharif.edu/courses/90-91/2/ce153-1/resources... · Fundamentals of Programming Lecture 3 Hamed Rasifard 1. Outline ... [3], and so on until it completes

8

The Bubble Sort Code(Cont.)

printf( "\nData items in ascending order\n" );

/* output sorted array */ for ( i = 0; i < SIZE; i++ ) { printf( "%4d", a[ i ] ); } /* end for */ printf( "\n" ); return 0; /* indicates successful termination */ } /* end main */

Output:

218 Chapter 6 C Arrays

First the program compares a[0] to a[1], then a[1] to a[2], then a[2] to a[3], andso on until it completes the pass by comparing a[8] to a[9]. Although there are 10 ele-ments, only nine comparisons are performed. Because of the way the successive compari-sons are made, a large value may move down the array many positions on a single pass, buta small value may move up only one position. On the first pass, the largest value is guar-anteed to sink to the bottom element of the array, a[9]. On the second pass, the second-largest value is guaranteed to sink to a[8]. On the ninth pass, the ninth-largest value sinksto a[1]. This leaves the smallest value in a[0], so only nine passes of the array are neededto sort the array, even though there are ten elements.

The sorting is performed by the nested for loop (lines 24–37). If a swap is necessary,it’s performed by the three assignments

where the extra variable hold temporarily stores one of the two values being swapped. Theswap cannot be performed with only the two assignments

If, for example, a[i] is 7 and a[i + 1] is 5, after the first assignment both values will be 5and the value 7 will be lost. Hence the need for the extra variable hold.

The chief virtue of the bubble sort is that it’s easy to program. However, the bubblesort runs slowly because every exchange moves an element only one position closer to itsfinal destination. This becomes apparent when sorting large arrays. In the exercises, we’lldevelop more efficient versions of the bubble sort. Far more efficient sorts than the bubblesort have been developed. We’ll investigate a few of these in the exercises. More advancedcourses investigate sorting and searching in greater depth.

6.7 Case Study: Computing Mean, Median and Mode Using ArraysWe now consider a larger example. Computers are commonly used for survey data analysisto compile and analyze the results of surveys and opinion polls. Figure 6.16 uses array re-sponse initialized with 99 responses to a survey. Each response is a number from 1 to 9. Theprogram computes the mean, median and mode of the 99 values.

The mean is the arithmetic average of the 99 values. Function mean (line 40) com-putes the mean by totaling the 99 elements and dividing the result by 99.

The median is the “middle value.” Function median (line 61) determines the medianby calling function bubbleSort (defined in line 133) to sort the array of responses into

Data items in original order 2 6 4 8 10 12 89 68 45 37Data items in ascending order 2 4 6 8 10 12 37 45 68 89

hold = a[ i ];a[ i ] = a[ i + 1 ];a[ i + 1 ] = hold;

a[ i ] = a[ i + 1 ];a[ i + 1 ] = a[ i ];

Fig. 6.15 | Sorting an array with bubble sort. (Part 2 of 2.)

Page 9: Fundamentals of Programmingce.sharif.edu/courses/90-91/2/ce153-1/resources... · Fundamentals of Programming Lecture 3 Hamed Rasifard 1. Outline ... [3], and so on until it completes

9

Computing Mean, Median, and mode

#include <stdio.h> #define SIZE 99 /* function prototypes */ void mean( const int answer[] ); void median( int answer[] ); void mode( int freq[], const int answer[] ) ; void bubbleSort( int a[] ); void printArray( const int a[] ); /* function main begins program execution */ int main( void ) { int frequency[ 10 ] = { 0 }; /* initialize array frequency */

Page 10: Fundamentals of Programmingce.sharif.edu/courses/90-91/2/ce153-1/resources... · Fundamentals of Programming Lecture 3 Hamed Rasifard 1. Outline ... [3], and so on until it completes

10

Computing Mean, Median, and

mode(cont.) /* initialize array response */ int response[ SIZE ] = { 6, 7, 8, 9, 8, 7, 8, 9, 8, 9, 7, 8, 9, 5, 9, 8, 7, 8, 7, 8, 6, 7, 8, 9, 3, 9, 8, 7, 8, 7, 7, 8, 9, 8, 9, 8, 9, 7, 8, 9, 6, 7, 8, 7, 8, 7, 9, 8, 9, 2, 7, 8, 9, 8, 9, 8, 9, 7, 5, 3, 5, 6, 7, 2, 5, 3, 9, 4, 6, 4, 7, 8, 9, 6, 8, 7, 8, 9, 7, 8, 7, 4, 4, 2, 5, 3, 8, 7, 5, 6, 4, 5, 6, 1, 6, 5, 7, 8, 7 }; /* process responses */ mean( response ); median( response ); mode( frequency, response ); return 0; /* indicates successful termination */ } /* end main */

Page 11: Fundamentals of Programmingce.sharif.edu/courses/90-91/2/ce153-1/resources... · Fundamentals of Programming Lecture 3 Hamed Rasifard 1. Outline ... [3], and so on until it completes

11

Computing Mean, Median, and

mode(cont.) void mean( const int answer[] ) { int j; /* counter for totaling array elements */ int total = 0; /* variable to hold sum of array elements */ printf( "%s\n%s\n%s\n", "********", " Mean", "********" ); /* total response values */ for ( j = 0; j < SIZE; j++ ) { total += answer[ j ]; } /* end for */ printf( "The mean is the average value of the data\n" "items. The mean is equal to the total of\n" "all the data items divided by the number\n" "of data items ( %d ). The mean value for\n" "this run is: %d / %d = %.4f\n\n", SIZE, total, SIZE, ( double ) total / SIZE ); } /* end function mean */

Page 12: Fundamentals of Programmingce.sharif.edu/courses/90-91/2/ce153-1/resources... · Fundamentals of Programming Lecture 3 Hamed Rasifard 1. Outline ... [3], and so on until it completes

12

Computing Mean, Median, and

mode(cont.) /* sort array and determine median element's value */ void median( int answer[] ) { printf( "\n%s\n%s\n%s\n%s", "********", " Median", "********", "The unsorted array of responses is" ); printArray( answer ); /* output unsorted array */

bubblesort(answer); printf( "\n\nThe sorted array is" ); printArray( answer ); /* output sorted array */ /* display median element */ printf( "\n\nThe median is element %d of\n" "the sorted %d element array.\n" "For this run the median is %d\n\n", SIZE / 2, SIZE, answer[ SIZE / 2 ] ); } /* end function median */

Page 13: Fundamentals of Programmingce.sharif.edu/courses/90-91/2/ce153-1/resources... · Fundamentals of Programming Lecture 3 Hamed Rasifard 1. Outline ... [3], and so on until it completes

13

Computing Mean, Median, and

mode(cont.) /* determine most frequent response */ void mode( int freq[], const int answer[] ) { int rating; /* counter for accessing elements 1-9 of array freq */ int j; /* counter for summarizing elements 0-98 of array answer */ int h; /* counter for diplaying histograms of elements in array freq */ int largest = 0; /* represents largest frequency */ int modeValue = 0; /* represents most frequent response */ printf( "\n%s\n%s\n%s\n", "********", " Mode", "********" );/* initialize frequencies to 0 */ for ( rating = 1; rating <= 9; rating++ ) { freq[ rating ] = 0; } /* end for */ /* summarize frequencies */   for(j = 0; j < SIZE; j++){   ++freq[ answer[ j ] ];   }/*end for*/

Page 14: Fundamentals of Programmingce.sharif.edu/courses/90-91/2/ce153-1/resources... · Fundamentals of Programming Lecture 3 Hamed Rasifard 1. Outline ... [3], and so on until it completes

Computing Mean, Median, and

mode(cont.)

14

/* output headers for result columns */ printf( "%s%11s%19s\n\n%54s\n%54s\n\n", "Response", "Frequency", "Histogram", "1 1 2 2", "5 0 5 0 5" ); /* output results */ for ( rating = 1; rating <= 9; rating++ ) { printf( "%8d%11d ", rating, freq[ rating ] );

/* keep track of mode value and largest frequency value */ if ( freq[ rating ] > largest ) {

largest = freq[ rating ]; modeValue = rating; } /* end if */

/* output histogram bar representing frequency value */ for ( h = 1; h <= freq[ rating ]; h++ ) { printf( "*" ); } /* end inner for */ printf( "\n" ); /* being new line of output */ } /* end outer for *//* keep track of mode value and largest frequency value */ if ( freq[ rating ] > largest ) { largest = freq[ rating ]; modeValue = rating; } /* end if */

Page 15: Fundamentals of Programmingce.sharif.edu/courses/90-91/2/ce153-1/resources... · Fundamentals of Programming Lecture 3 Hamed Rasifard 1. Outline ... [3], and so on until it completes

15

Computing Mean, Median, and

mode(cont.) /* display the mode value */ printf( "The mode is the most frequent value.\n" "For this run the mode is %d which occurred" " %d times.\n", modeValue, largest ); } /* end function mode */ /* function that sorts an array with bubble sort algorithm */ void bubbleSort( int a[] ) { int pass; /* pass counter */ int j; /* comparison counter */ int hold; /* temporary location used to swap elements */ /* loop to control number of passes */ for ( pass = 1; pass < SIZE; pass++ ) { /* loop to control number of comparisons per pass */ for ( j = 0; j < SIZE - 1; j++ ) {/* swap elements if out of order */ if ( a[ j ] > a[ j + 1 ] ) {

Page 16: Fundamentals of Programmingce.sharif.edu/courses/90-91/2/ce153-1/resources... · Fundamentals of Programming Lecture 3 Hamed Rasifard 1. Outline ... [3], and so on until it completes

16

Computing Mean, Median, and

mode(cont.) hold = a[ j ]; a[ j ] = a[ j + 1 ]; a[ j + 1 ] = hold; } /* end if */ } /* end inner for */ } /* end outer for */ } /* end function bubbleSort */ /* output array contents (20 values per row) */ void printArray( const int a[] ) { int j; /* counter */ /* output array contents */ for ( j = 0; j < SIZE; j++ ) { if ( j % 20 == 0 ) { /* begin new line every 20 values */ printf( "\n" ); } /* end if */ printf( "%2d", a[ j ] ); } /* end for */ } /* end function printArray */

Page 17: Fundamentals of Programmingce.sharif.edu/courses/90-91/2/ce153-1/resources... · Fundamentals of Programming Lecture 3 Hamed Rasifard 1. Outline ... [3], and so on until it completes

Output

17

222 Chapter 6 C Arrays

145 /* swap elements if out of order */146 if ( a[ j ] > a[ j + 1 ] ) {147 hold = a[ j ];148 a[ j ] = a[ j + 1 ];149 a[ j + 1 ] = hold;150 } /* end if */151 } /* end inner for */152 } /* end outer for */153 } /* end function bubbleSort */154155 /* output array contents (20 values per row) */156 void printArray( const int a[] )157 {158 int j; /* counter */159160 /* output array contents */161 for ( j = 0; j < SIZE; j++ ) {162163 if ( j % 20 == 0 ) { /* begin new line every 20 values */164 printf( "\n" );165 } /* end if */166167 printf( "%2d", a[ j ] );168 } /* end for */169 } /* end function printArray */

******** Mean********The mean is the average value of the dataitems. The mean is equal to the total ofall the data items divided by the numberof data items ( 99 ). The mean value forthis run is: 681 / 99 = 6.8788

******** Median********The unsorted array of responses is 6 7 8 9 8 7 8 9 8 9 7 8 9 5 9 8 7 8 7 8 6 7 8 9 3 9 8 7 8 7 7 8 9 8 9 8 9 7 8 9 6 7 8 7 8 7 9 8 9 2 7 8 9 8 9 8 9 7 5 3 5 6 7 2 5 3 9 4 6 4 7 8 9 6 8 7 8 9 7 8 7 4 4 2 5 3 8 7 5 6 4 5 6 1 6 5 7 8 7

The sorted array is 1 2 2 2 3 3 3 3 4 4 4 4 4 5 5 5 5 5 5 5 5 6 6 6 6 6 6 6 6 6 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 8 8 8 8 8 8 8

Fig. 6.17 | Sample run for the survey data analysis program. (Part 1 of 2.)

Fig. 6.16 | Survey data analysis program. (Part 4 of 4.)

Page 18: Fundamentals of Programmingce.sharif.edu/courses/90-91/2/ce153-1/resources... · Fundamentals of Programming Lecture 3 Hamed Rasifard 1. Outline ... [3], and so on until it completes

Output(Cont.)

18

6.8 Searching Arrays 223

6.8 Searching ArraysYou’ll often work with large amounts of data stored in arrays. It may be necessary to de-termine whether an array contains a value that matches a certain key value. The process offinding a particular element of an array is called searching. In this section we discuss twosearching techniques—the simple linear search technique and the more efficient (butmore complex) binary search technique. Exercise 6.32 and Exercise 6.33 at the end of thischapter ask you to implement recursive versions of the linear search and the binary search.

Searching an Array with Linear SearchThe linear search (Fig. 6.18) compares each element of the array with the search key. Sincethe array is not in any particular order, it’s just as likely that the value will be found in thefirst element as in the last. On average, therefore, the program will have to compare thesearch key with half the elements of the array.

8 8 8 8 8 8 8 8 8 8 8 8 8 8 8 8 8 8 8 8 9 9 9 9 9 9 9 9 9 9 9 9 9 9 9 9 9 9 9

The median is element 49 ofthe sorted 99 element array.For this run the median is 7

******** Mode********Response Frequency Histogram

1 1 2 2 5 0 5 0 5

1 1 * 2 3 *** 3 4 **** 4 5 ***** 5 8 ******** 6 9 ********* 7 23 *********************** 8 27 *************************** 9 19 *******************The mode is the most frequent value.For this run the mode is 8 which occurred 27 times.

1 /* Fig. 6.18: fig06_18.c2 Linear search of an array */3 #include <stdio.h>4 #define SIZE 100

Fig. 6.18 | Linear search of an array. (Part 1 of 3.)

Fig. 6.17 | Sample run for the survey data analysis program. (Part 2 of 2.)