-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathReverseInsideParentheses.c
More file actions
64 lines (60 loc) · 1.48 KB
/
ReverseInsideParentheses.c
File metadata and controls
64 lines (60 loc) · 1.48 KB
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
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#define t 0
char * reverse_in_parens(const char *text)
{
char *m = (char *) malloc(
strlen(text) * sizeof(char)
);
int b[2];
int e = 0, c = 1;
memcpy(m, text, strlen(text) );
printf("%s len:%d \n", text, strlen(text));
for(size_t i = 0; i < strlen(text); i ++)
{
if( ((int) text[i] ) == 40 && e == 0) // "("
{ b[0] = i; e++; }
if( ( (int) text[i] ) == 41) b[1] = i; // ")"
}
// printf("Strt %d End %d bfrSize %d\n", b[0], b[1], (b[1] - b[0]) + 1);
char bfr[ (b[1] - b[0]) + 1];
e = 0;
for(int j = b[0] + 1; j < b[1]; j ++) // boundaries
{
printf("%d ", c);
if( ( (int)text[(b[1] - (c + 1)) + 1] ) == 41 // )
&& e == 0)
{
size_t p_s = 0; int cc = 0;
for(size_t k = 0; k < strlen(text)/2; k++)
{
if( (int)text[((b[1] - (c + 1)) + 1) - k] == 40){ // (
p_s = k - 1;
break;
}
}
for(size_t l = p_s ; l <= (b[1] - (c + 1)) + 1; l++)
{
bfr[c + cc] = text[l];
cc++;
}
j +=cc;
}
else {
bfr[c] = text[(b[1] - (c + 1)) + 1];
c++;
}
}
bfr[0] = '('; bfr[(b[1] - b[0])] = ')';
bfr[ ((b[1] - b[0])) + 2] = '\0';
printf("reversed buffer %s \n", bfr);
for(size_t z = 0; z < strlen(bfr); z ++)
{
*(m + (z + b[0]) ) = bfr[z];
}
printf("%s len:%d \n \n", m, strlen(m));
text = m;
if(e == 0 && 1 == 0) return reverse_in_parens(m);
return m;
}