-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathLesson4-3-MaxCounters.c
35 lines (31 loc) · 1.12 KB
/
Lesson4-3-MaxCounters.c
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
/*Calculate the values of counters after applying all alternating operations:
increase counter by 1; set value of all counters to current maximum. */
//Detected time complexity: O(N + M)
void init_max(int *ptr,int size, int set_to_max);
struct Results solution(int N, int A[], int M) {
int max=0,set_to_max=0;
struct Results result;
// write your code in C99 (gcc 6.2.0)
result.C = (int *)calloc(N,sizeof(int));//initial new arr with zeros
for(int i=0; i<M;i++){
if(A[i]<=N){//increase element by 1 and update the max value
if(result.C[A[i]-1]<set_to_max)
result.C[A[i]-1]=set_to_max;
result.C[A[i]-1]+=1;
if(result.C[A[i]-1]>max)
max=result.C[A[i]-1];
}
else{
set_to_max=max; //update the set value
}
}
// at the end set elements that lesser than set_to_max to set_to_max
init_max(result.C,N,set_to_max);
result.L = N;
return result;
}
void init_max(int *ptr,int size, int set_to_max){
for(int i=0;i<size;i++)
if(*(ptr+i)<set_to_max)
*(ptr+i)=set_to_max;
}