split plus court

This commit is contained in:
hugodu69
2019-12-04 02:23:50 +01:00
parent 7e0fc1e626
commit bc40b73a9a

View File

@@ -15,13 +15,14 @@
*/ */
#include <libc.h> #include <stdio.h>
#include <stdlib.h>
#include <unistd.h>
size_t ft_strlen(const char *str) size_t ft_strlen(const char *str)
{ {
size_t i; size_t i;
write (1, "gr\n", 3);
i = 0; i = 0;
while (str[i]) while (str[i])
i++; i++;
@@ -47,6 +48,7 @@
} }
char **ft_split(char const *s, char c); char **ft_split(char const *s, char c);
char **ft_strsplit(char const *s, char c);
//int main(int ac, char **av) //int main(int ac, char **av)
int main(void) int main(void)
@@ -62,75 +64,119 @@
i = 0; i = 0;
// s = av[1]; // s = av[1];
// c = av[2][0]; // c = av[2][0];
s = ""; s = "ccucuucccuuuccuuuucuuuuuccc";
c = 'c'; c = 'c';
if ((str = ft_split(s, c))) // if ((str = ft_split(s, c)))
{ // {
str = ft_split(s, c);
while (str[i]) while (str[i])
printf("%s\n", str[i++]); printf("str[%i] : '%s'\n", i, str[i++]);
} // }
// } // }
return (0); return (0);
} }
//TEST
static int ft_cnt_parts(const char *s, char c)
{
int cnt;
int in_substring;
in_substring = 0;
cnt = 0;
while (*s != '\0')
{
if (in_substring == 1 && *s == c)
in_substring = 0;
if (in_substring == 0 && *s != c)
{
in_substring = 1;
cnt++;
}
s++;
}
return (cnt);
}
static int ft_wlen(const char *s, char c)
{
int len;
len = 0;
while (*s != c && *s != '\0')
{
len++;
s++;
}
return (len);
}
char **ft_strsplit(char const *s, char c)
{
char **t;
int nb_word;
int index;
index = 0;
nb_word = ft_cnt_parts((const char *)s, c);
t = (char **)malloc(sizeof(*t) * (ft_cnt_parts((const char *)s, c) + 1));
if (t == NULL)
return (NULL);
while (nb_word--)
{
while (*s == c && *s != '\0')
s++;
t[index] = ft_substr((const char *)s, 0, ft_wlen((const char *)s, c));
if (t[index] == NULL)
return (NULL);
s = s + ft_wlen(s, c);
index++;
}
t[index] = NULL;
return (t);
}
//TESTFIN
//#include "libft.h" //#include "libft.h"
static int ft_count_word(char const *s, char c) static int count(char const *s, char c)
{ {
int i; int i;
int words; int words;
write (1, "gt\n", 3); i = -1;
i = 0;
words = 0; words = 0;
while (s[i]) while (s[++i])
{ if (s[i] != c && ++words)
if (s[i] != c) while (s[i + 1] && s[i + 1] != c)
{
words++;
while (s[i] && s[i] != c)
i++; i++;
}
else
i++;
}
return (words); return (words);
} }
void *ft_free(char **array)
{
while (array)
free(array++);
return (NULL);
}
char **ft_split(char const *s, char c) char **ft_split(char const *s, char c)
{ {
char **array; char **array;
int i; int w;
int j;
int len; int len;
write (1, "gu\n", 3); w = 0;
if (!s || !c || !(i = ft_count_word(s, c))) if (!s || !c || !(array = malloc(sizeof(char *) * (count(s, c) + 1))))
return (NULL); return (NULL);
if (!(array = malloc(sizeof(char *) * (i + 1)))) while (*s && !(len = 0))
return (NULL);
array[i] = 0;
i = -1;
j = 0;
while (s[++i])
{ {
if (s[i] != c) if (*s != c)
{ {
len = 0; while (s[len] && s[len] != c)
while (s[i + len] && s[i + len] != c)
len++; len++;
if (!(array[j++] = ft_substr(s, i, len))) if (!(array[w++] = ft_substr(s, 0, len)))
return (ft_free(array)); {
i = i + len - 1; while (array)
free(array++);
return (NULL);
}
} }
s += len ? len : 1;
} }
array[w] = NULL;
return (array); return (array);
} }