Counting Valleys Hackerrank solution in c
We define the following terms:
- A mountain is a non-empty sequence of consecutive steps above sea level, starting with a step up from sea level and ending with a step down to sea level.
- A valley is a non-empty sequence of consecutive steps below sea level, starting with a step down from sea level and ending with a step up to sea level.
Input Format
The first line contains an integer, n, denoting the number of steps in Gary's hike.
The second line contains a single string of n characters. Each character is ∊{U,D} (where U indicates a
step up and D indicates a step down), and the ith character in the string describes Gary's ith step during the
hike.
Constraints
- 2 ≤ N ≥ 10^6
Output Format
Print a single integer denoting the number of valleys Gary walked through during his hike.
Sample Input
8
UDDDUDUU
Sample Output
1
Explanation
If we represent _ as sea level, a step up as / , and a step down as \ , Gary's hike can be drawn as:
_/\ _
\ /
\/\/
It's clear that there is only one valley there, so we print on a new line.
How to solve this problem.
lets's see how can we solve this problem.
Suppose this is a valley
Here we can see that number of U = D, Means the number of up step count is equal to number of down step. Now if we take +1 to up step and -1 to down to step it will count 0 to make a complete valley. But we will also have to check that if it is 0 then it must be with up step.
How to solve this problem.
lets's see how can we solve this problem.
Suppose this is a valley
_/\ _
\ /
\/\/
Character wise representation
Character wise representation
_UD _
D U
DUDU D U
Here we can see that number of U = D, Means the number of up step count is equal to number of down step. Now if we take +1 to up step and -1 to down to step it will count 0 to make a complete valley. But we will also have to check that if it is 0 then it must be with up step.
int countingValleys(int n, char* s) {
int count=0,v=0;
scanf("%d",&n);
for(int i=0;i<n;i++)
{
if(s[i] == 'D')
count--;
else if(s[i] == 'U')
{
count++;
if(count == 0 && s[i] == 'U')// This is the most important part
v++;
}
}
return v;
}Full code is given below;
#include <assert.h>
#include <limits.h>
#include <math.h>
#include <stdbool.h>
#include <stddef.h>
#include <stdint.h>
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
char* readline();
// Complete the countingValleys function below.
int countingValleys(int n, char* s) {
int count=0,v=0;
scanf("%d",&n);
for(int i=0;i<n;i++)
{
if(s[i] == 'D')
count--;
else if(s[i] == 'U')
{
count++;
if(count == 0 && s[i] == 'U')
v++;
}
}
return v;
}
int main()
{
FILE* fptr = fopen(getenv("OUTPUT_PATH"), "w");
char* n_endptr;
char* n_str = readline();
int n = strtol(n_str, &n_endptr, 10);
if (n_endptr == n_str || *n_endptr != '\0') { exit(EXIT_FAILURE); }
char* s = readline();
int result = countingValleys(n, s);
fprintf(fptr, "%d\n", result);
fclose(fptr);
return 0;
}
char* readline() {
size_t alloc_length = 1024;
size_t data_length = 0;
char* data = malloc(alloc_length);
while (true) {
char* cursor = data + data_length;
char* line = fgets(cursor, alloc_length - data_length, stdin);
if (!line) { break; }
data_length += strlen(cursor);
if (data_length < alloc_length - 1 || data[data_length - 1] == '\n') { break; }
size_t new_length = alloc_length << 1;
data = realloc(data, new_length);
if (!data) { break; }
alloc_length = new_length;
}
if (data[data_length - 1] == '\n') {
data[data_length - 1] = '\0';
}
data = realloc(data, data_length);
return data;
}
Comments
Post a Comment