Vježba za 2. međuispit

advertisement
Algorithms and Data Structures
Exercise for the 1st Written Exam (23 April 2014, 9:00 am)
Dynamic Memory Allocation, Function Calls,
Complexity Analysis
Dynamic Memory Allocation
Assignment 1:
 Write the function that takes an array of integers and removes its members
containing even values. Based on the new number of array elements, the function
dynamically decreases the size of the array and returns the pointer to this array. The
prototype of the function is:
int *remove_even(int *array, int *elem_num);
 Wrtite the main program that dynamically allocates the memory for the array,
fills the array with random values, calls the function remove_even, prints out
the new array, and, finally, releases dynamically allocated memory.
 Note: after removal, the mutual order of members with odd values is not important
Solution (function):
int *remove_even(int *array, int *elem_num){
int i, j;
for(i=0; i<*elem_num;){
if (array[i] % 2 == 0){
for(j=i+1; j<*elem_num; j++)
array[j-1] = array[j];
(*elem_num)--;
} else
i++;
}
array = (int*) realloc(array, *elem_num * sizeof(int));
return array;
}
int main(){
Solution (main program):
int *array, i, elem_num = 20;
array = (int*) malloc(elem_num * sizeof(int));
srand((unsigned) time(NULL));
for(i=0; i< elem_num; i++){
array[i] = rand();
}
printf("\nBefore removal\n");
for(i=0; i< elem_num; i++){
printf("%d\n", array[i]);
}
array = remove_even(array, &elem_num);
printf("\nAfter removal\n");
for(i=0; i<elem_num; i++){
printf("%d\n", array[i]);
}
free(array);
return 0;
}
Assignment 2:
 Write the function that takes an array of integers and duplicates it
(creates new duplicated array). The function returns the pointer to the
duplicated array.The prototype of the function is:
int *duplicate(int *array, int elem_num);
 Wrtite the main program that defines an array of 50 elements, fills
the array with random integers from the range [1-20], calls the function
duplicate, prints out the new array, and, finally, releases dynamically
allocated memory.
Solution (function & main program):
int *duplicate(int *array, int elem_num){
int i, *new_array;
new_array = (int*) malloc(elem_num * sizeof(int));
for(i=0; i<elem_num; i++)
new_array[i] = array[i];
return new_array;
}
int main(){
int array1[50], *array2, i, elem_num = 50;
srand((unsigned) time(NULL));
for(i=0; i<elem_num; i++){
array1[i] = 1+rand()%20;
}
array2 = duplicate(array1, elem_num);
for(i=0; i<elem_num; i++){
printf("%d\n", array2[i]);
}
free(array2);
return 0;
}
Assignment 3 (Written Exam 21 March 2011):
 Write the function remove_row that takes the index of the matrix row and removes
that row from the matrix (some rows must be shifted). This function releases the unnecessary
memory allocated for that matrix. The rest of the matrix must be preserved. The prototype
of the function is:
int *remove_row(int *mat, int rown, int coln, int irow);
 Write the main program that dynamically allocates the matrix mat and fills it with
pseudo-random integers. In the main program input the number of matrix rows and columns:
rown and coln, lower and the upper bound of the range for the generation of pseudorandom numbers. Then, allocate the needed memory and fill in the matrix with pseudorandom numbers from the given range.
 In the main program, ask the user to input the index of matrix row irow and call the
function remove_row.
Solution (function):
int *remove_row(int * mat, int rown, int coln, int irow){
int i, j;
for (i = irow + 1; i<rown; i++)
for (j = 0; j<coln; j++)
*(mat + (i - 1)*coln + j) = *(mat + (i)*coln + j);
mat = (int *)realloc(mat, (rown - 1)* coln *sizeof(int));
return mat;
}
Solution (main):
int main(){
int *mat, i, j, irow;
int rownum, colnum, LB, UB;
printf("Input the number of rows, columns, lower bound, and the
upper bound: \n");
scanf("%d %d %d %d", &rownum, &colnum, &LB, &UB);
mat = (int *)malloc(rownum*colnum*sizeof(int));
srand((unsigned)time(NULL));
for (i = 0; i<rownum; i++)
for (j = 0; j<colnum; j++)
mat[i*colnum + j] = rand() % (UB - LB + 1) + LB;
printf("Input the index of the row to remove: \n");
do{
scanf("%d", &irow);
} while (irow<0 || irow>rownum);
mat = remove_row(mat, rownum, colnum, irow);
free(mat);
return 0;
}
Function Call
Assignment 4:
 Illustrate the system stack during the call and execution of the function sum, and at the call
of the function add:
int add(int first, int second){
return a+b;
}
void sum(int a, char b, int * s){
int c;
c=add(a,b);
if (c<0) c=-c;
*s=c;
}
 The function call is:
int s;
sum(5, 7, &s);
Solution:
return address from add
first
second
local variable c
return address from sum
a
b
s
Assignment 5 (Written Exam 21 March 2011):
 Illustrate the system stack just before the exit from the function f2. Indicate what is the size of
each variable on the stack:
void f2(double *a, int *b, int n){
int counter[10]={0};
a[n]=b[n];
counter[n%10]++;
}
void f1(int *array, int n) {
double *array2;
int i;
array2=(double*)malloc(n*sizeof(
double));
for(i=0;i<n;i++)
f2(array2,array,n-i-1);
}
int main() {
int array[100];
...
f1(array, 100);
}
Solution:
40
counter
4
return address - f2
4
array2
4
array
4
n-i-1
4
i
4
array2
4
return address - f1
4
array
4
100
Complexity Analysis
Assignment 6:
 What is the time complexity of the following program section, in O and  notation?
 The answer MUST be argumented!
for (i = 0; i < n; i++) {
if (p[i][i] == i){
printf("%d", i);
break;
}
}
O(n) – the worst case
is when it is for each
i, p[i][i]!=i. In that
case the loop
(statement if inside
the loop) executes n
times.
(1) – the best case is
when p[0][0]==0. Then
for loop terminates
with break; after
execution of two
statements
Assignment 7:
 What is the time complexity of the following program section ( in bold), in O notation?
 The answer MUST be argumented!
int b;
...
The number n is constantly divided by
2. We finish
when n is 1 (i.e. n/2 =
char *rezultat
= ...
0). How many steps do we need to come
rezultat[0]
'\0';
to =
0 (i.e.
1) when dividing by 2:
k in k-th step. Solve
while (n n,> n/2,
0) n/4,...n/2
{
n/2k = 1 for k. The number of steps is
if (n %log2 n.==In 1)
each step strcat is called.
2
rezultat
= have
strcat(rezultat,
Then, we
1+2+3+...+log2n i.e. "1");
the
solution is O((log2n)2).
else
rezultat = strcat(rezultat, "0");
n = n/2;
}
Assignment 8 (Written Exam 3 September 2013):
 What is the asymptotic complexity of the following algorithms:
 Take that the asymptotic complexity of the function work(x,y) is x
 The answer MUST be argumented!
2n2log2n
s=0;
for(i=1; i<=n; i*=2)
for(j=1; j<=n; j++)
s += work(n,j) + work(n,i);
s=0;
n2log2n
for(i=1; i<=n; i*=2)
for(j=1; j<=n; j++)
s += work(j,n) + work(j,i);
Download