Sunteți pe pagina 1din 3

//hackerrank train track

#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();
char** split_string(char*);

// Complete the gridlandMetro function below.


int gridlandMetro(int n, int m, int k, int track_rows, int track_columns, int**
track) {
int ar[n][m];
int i,j,r,a,b,c=0,s=0;

for(i=0;i<k;i++)
{
r=track[i][0];
a=track[i][1];
b=track[i][2];

for(j=a;j<=b;j++)
{
ar[r][j];
c++;
}
}

s=(n*m)-c;
return s;
}

int main()
{
FILE* fptr = fopen(getenv("OUTPUT_PATH"), "w");

char** nmk = split_string(readline());

char* n_endptr;
char* n_str = nmk[0];
int n = strtol(n_str, &n_endptr, 10);

if (n_endptr == n_str || *n_endptr != '\0') { exit(EXIT_FAILURE); }

char* m_endptr;
char* m_str = nmk[1];
int m = strtol(m_str, &m_endptr, 10);

if (m_endptr == m_str || *m_endptr != '\0') { exit(EXIT_FAILURE); }

char* k_endptr;
char* k_str = nmk[2];
int k = strtol(k_str, &k_endptr, 10);
if (k_endptr == k_str || *k_endptr != '\0') { exit(EXIT_FAILURE); }

int** track = malloc(k * sizeof(int*));

for (int i = 0; i < k; i++) {


*(track + i) = malloc(3 * (sizeof(int)));

char** track_item_temp = split_string(readline());

for (int j = 0; j < 3; j++) {


char* track_item_endptr;
char* track_item_str = *(track_item_temp + j);
int track_item = strtol(track_item_str, &track_item_endptr, 10);

if (track_item_endptr == track_item_str || *track_item_endptr != '\0')


{ exit(EXIT_FAILURE); }

*(*(track + i) + j) = track_item;
}
}

int track_rows = k;
int track_columns = 3;

int result = gridlandMetro(n, m, k, track_rows, track_columns, track);

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;
}

char** split_string(char* str) {


char** splits = NULL;
char* token = strtok(str, " ");

int spaces = 0;

while (token) {
splits = realloc(splits, sizeof(char*) * ++spaces);
if (!splits) {
return splits;
}

splits[spaces - 1] = token;

token = strtok(NULL, " ");


}

return splits;
}

S-ar putea să vă placă și